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This manual describes the operation of an installation of IBM Elec¬ 
tronic Data Processing Machines consisting of the following units 

1 Type 701 Electronic Analytical Control Unit 

2 Type 706 Electrostatic Storage Units 
1 Type 711 Punched Card Reader 

1 Type 716 Alphabetical Printer 

1 Type 721 Punched Card Recorder 

2 Type 726 Magnetic Tape Readers and Recorders 

1 Type 731 Magnetic Drum Reader and Recorder 

Other units, which are not listed, have to do with power supply and 
distribution. 
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f o r ewo r d 


Of IBM's many important contributions to the field 
of electronic business and scientific equipment, none 
has shown greater promise than the new class of 
equipment known as Electronic Data Processing Ma¬ 
chines. This equipment, expanding electronics into 
previously untouched areas, has been made possible 
by drawing on IBM's tremendous reservoir of expe¬ 
rience in electronics. 

These new machines are being designed for the 
higher speeds and larger capacities demanded by 
problems of increasing complexity which confront 
business, industry,'government and science. These 
problems include procurement and supply, logistics, 
econometrics, production control, engineering devel¬ 
opment, and scientific research. 

IBM Electronic Data Processing Machines will 
incorporate the newest devices for input, output, and 
storage, including magnetic tapes, magnetic drums, 
and cathode-ray tubes. Individual machines will be of 
portable size and specialized function. Some units will 
serve for control, arithmetic, and logical operations; 


others will provide for the input, output, or storing 
of data. 

This manual describes a representative installation 
of present equipment—one that is intended primarily 
for engineering and scientific calculations. For sim¬ 
plicity, the complete name of this installation, IBM 
Electronic Data Processing Machines Type 701 and 
Associated Equipment, will be abbreviated to 701. 

Among the outstanding features of the 701 are its 
large capacity high-speed electrostatic storage, inter¬ 
mediate magnetic drum storage, magnetic tape units, 
a versatile and fast input-output system, and comput¬ 
ing speed characterized by a multiplication time of 
456 microseconds. 

In order to achieve maximum versatility, every 
function of the machine is under control of the stored 
program. This versatility allows the machine to 
execute instructions at the rate of about 14.000 per 
second on typical problems. Also, functions such as 
input-output operation, which are determined by fixed 
circuitry on some computers, are under complete con¬ 
trol of the program and, hence, under complete control 
of the operator. The great advantage of this system 
lies in the fact that a customer may build up a library 
of programs which will accomplish his special appli¬ 
cations at peak machine efficiency. No compromise in 
efficiency is necessary in the design of the machine to 
accommodate an average application. Furthermore, a 
customer may efficiently calculate on any 701 installa¬ 
tion simply by using his own library of programs. 
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GENERAL 


THE 701 is a large-scale electronic digital computer 
controlled by a stored program of the one-address 
type, and utilizing various types of internal storage. 

The internal high-speed memory is on cathode- 
ray tubes and will be referred to as the “electrostatic 
memory. When the amount of storage available in 
the electrostatic memory is not large enough, mag¬ 
netic drums are used to store and supply large blocks 
of information for ready access at frequent intervals. 
The drum memory’’ is also capable of retaining its 
contents while the power is turned off, so that inter¬ 
mediate results remain available overnight when the 
machine is shut down. Any part of the information 
°n the drums may be selectively altered by the ma¬ 
chine at any time. 

If a larger secondary memory is needed, or if in¬ 
formation is to be filed away for future reference, 
ma gnetic tapes may be used instead of magnetic 


drums. Magnetic tape is a storage and input-output 
medium that provides compactness, allows rapid read¬ 
ing and writing and can be re-used many times. 

To achieve a greater computing efficiency, the ma¬ 
chine works internally in the binary-number system. 
The input and output, however, may be accomplished 
on standard IBM cards in the familiar decimal- 
number system by programming that does not inter¬ 
fere with maximum reading, punching, and printing 
speeds. 

Results of a computation are printed on a modified 
Type 407 accounting machine operating at a speed of 
over 10,000 characters per minute. Control of the 
automatic tape-controlled carriage may be accom¬ 
plished either manually, by control panel wiring, or 
by the stored program itself. Output can also take the 
form of cards punched in either binary or decimal; 
this again depends on the programming. 
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The programs may be written and introduced into 
the computer in various ways. Usually the instruc¬ 
tions are key-punched on cards in their original form 
and read into the machine. If the program is to be 
preserved for future use, it can then be recorded on 
tape and filed away in a compact form. To prepare 
the machine for calculation the appropriate magnetic 
tapes are inserted in the tape units, cards are placed 
in the punch hopper, if necessary, and the cards con¬ 
taining the instructions and data of the problem are 
placed in the hopper of the card reader. By pushing 
one button the machine may be made to store the 
program and data of the problem and start calculat¬ 
ing. From then on. operation of the computer is fully 
automatic, with all of the components being under 
the complete control of the program, although it is 
possible for the operator to interrupt the calculation 
manually at any time. 

The primary unit of information is defined as a 
full word which consists of 35 bits (binary digits) 
and a sign, or 36 bits in all. However, any of these 
full words can be split into two "half words," each 
having 17 bits and a sign, or 18 bits in all. Since 3 l /s 
bits are about equivalent in information content to 
one decimal digit, the full word has a precision of 
about ten decimal digits, and the half-word corre¬ 
sponds to about five decimal digits. 


Full Word 
— 1962 



Figure 1 

Figure 1 shows schematically a full word and the 
two half-words contained in the full word. The posi¬ 
tion of each of the 35 binary bits within the full word 
is numbered 1 through 35 from left to right. The sign 
bit of the number is represented on the extreme left 
and is labeled S. If this full word is divided between 
the 17th and 18th positions, the positions in the left 
half-word are designated exactly as in the full word. 
However, the 18th position of the full word now be¬ 
comes the sign position of the riff/it half-word, while 
the remaining positions are numbered 1 through 17 
A word is considered negative if the binary digit 1 
occupies the sign position; it is considered positive ii 
the sign position contains the digit 0. 
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STORAGE 


In formation may be stored in electrostatic storage, 
on magnetic drums, on magnetic tape, and on 
punched cards. 

The purpose of this section is simply to point out, 
in general terms, the types and extent of storage 
available on the 701. Punched cards are a well-known 
form of permanent storage and will receive extensive 
discussion in the input-output section of this manual. 
Details of the instructions necessary for manipulation 
of information contained on drums and tapes will 
also be found in the same section. 

ELECTROSTATIC 

The heart of the machine is the electrostatic storage 
unit, through which all information to and from all 
other components of the machine must pass. Electro¬ 
static storage consists of a bank of cathode-ray tubes. 
Information is stored on the screen of each tube 
through the presence or absence of charged spots at 
certain locations on the screen. In this way, a certain 


number of binary digits (or “bits") may be stored on 
each tube. One electrostatic storage unit can accom¬ 
modate 2048 full words or 4096 half words. How¬ 
ever, two such units may be used to provide a maxi¬ 
mum storage of 4096 full words or 8192 half words. 
Instructions follow for both one electrostatic storage 
unit and two electrostatic units (double storage). 

Principal advantages of electrostatic storage over 
other types is the very small time necessary to extract 
information from any given location and send it to 
the computing unit and the fact that the programmer 
has random access to any electrostatic-storage loca¬ 
tion. Information is lost when the power is turned off. 

MAGNETIC DRUMS 

Additional storage capacity is provided by four 
magnetic drums. These drums are rotating cylinders 
surfaced with a material that can be magnetized 
locally. Binary digits are stored on a drum through 
the presence or absence of small magnetized areas at 
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certain locations on the surface of the drum. Each 
drum has a storage capacity of 2048 full words. 
Information is transmitted to and from drum storage 
only through electrostatic storage. When such a 
transfer of information occurs, the machine is said to 
write on or read from the drum. Any part of the 
information on a drum can be selectively altered by 
the machine at any time. Because access to individual 
words on a drum is slow in relation to electrostatic 
storage access, it is more efficient to use the drums 
for storing large blocks of information. After the 
first word of such a block has been located, the re¬ 
maining words are read at the rate of 800 per second. 
Magnetic drums will retain stored information after 
the power is off. 

MAGNETIC TAPES 

There is also a tape-storage section which includes 
four magnetic tape units. Each tape, which may be 


up to 1400 feet long, is wound on a reel. The tape 
itself is a non-metallic, oxide coated band one-half 
inch wide. Binary information is recorded on tape by 
means of magnetized spots. A block of words re¬ 
corded consecutively on a tape is called a record or 
unit record. The amount of information contained on 
each tape depends on the lengths of the individua| 
records, since there is a certain amount of space be' 
tween each record to allow for starting and stopping 
the tape. It is possible to store upwards of 200,000 
words on each tape. The machine can read or write 
information on a tape only through the medium of 
electrostatic storage. It takes, on the average, about 
10 milliseconds for the tape to accelerate to its read¬ 
ing or writing speed after which the reading or writ¬ 


ing of a unit record takes places at the rate of 1250| 


words per second. Since the tapes are removable, a 
library of standard programming and mathematical 
tables may be kept on tapes. 
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ADDRESS SYSTEM 


MEMORY LOCATIONS 

Full and half-word locations in electrostatic stor¬ 
age, together with the tapes, drums, printer, card 
reader, and punch, are identified by a system of 
numerical addresses. In double-storage operation, 
the same numerical addresses exist in each frame. 
A special method of inter-frame transfer is therefore 
required, as described in the following paragraphs. 

By means of a number, then, and proper control 
in the case of double storage operation, we may tell 
the machine to refer to any information contained in 
electrostatic storage or to any component of the ma¬ 
chine, provided only that we use the system to be 
described. 

Electrostatic 

The 4096 different locations for full words in 
double storage are identified by the negative integers 
fiom 0000 to —4095. The 8192 possible locations 
for half-words in double storage are distinguished by 
the positive integers from +0000 to +4095 and the 


status of a program-controlled trigger which lights 
the es2 light on the operator’s panel. When this trig¬ 
ger and light are on. the half-word location is in 
electrostatic storage unit 2. When this trigger is off, 
the half-word location is in electrostatic storage unit 
1. The relation between full and half-word addresses 
is as follows: If —In refers to a full-word location 
in electrostatic storage unit 1, then +2 u identifies the 
left half-word, and +(2;;+l) the right half-word, 
into which the full-word location may be split; if 
— (2«+l) refers to a full-word location in electro¬ 
static storage unit 2, then, also, +2 n identifies the 
left half-word, and + (2;;+l) the right half-word, 
into which the full-word location may be split. Thus, 
another bit must be programmed and remembered in 
order to identify fully the 8192 half-word locations in 
double storage. 

For example, if the full-word address is —1962, 
then the left half-word address is +1962 (esI) and 
refers to the sign position and positions 1 to 17 of the 
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full word. The right half-word address is +1963 
(esI ) and refers to positions 18 to 35 of the full- 
word location, position 18 being the sign position of 
the right half-word (Figure 1). La full word is to he 
obtained from or supplied to electrostatic storage 
and. through design, a negative odd address is given 
(e.g., —1963), the result concerns the physical ad¬ 
dress ( — 1962) in electrostatic storage unit 2. 

The following instructions refer to memory for 
information during their execution : 

Load MO register 


Subtract 

Peset and subtract 
Subtract absolute value 
Add 

Peset and add 
Add absolute value 


Multiply 

Multiply and round 
Divide 

Copy and skip (write) 


The following instructions store information in 


memory during their execution : 

Store Store contents of 

Extract MO register 

Store address Copy and skip (read ) 


Stxor.K F.i.kctrostatic Storace Operation 

If a full word is to be obtained from or supplied 
to electrostatic storage and, through error, a nega¬ 
tive odd address is given (e.g., —1963), the result 
is the same as if the next lower (in absolute value) 
negative even address { —1962) were given. 


Dorm.K Storaok Operation 

1. Tf any instruction which requires a reference to 
electrostatic memory during its execution is received, 
and has a negative even address, the execution refer¬ 
ence to electrostatic storage is to i:sl, in the form of 
a full word. For example: 

— radI) 0100 introduces the contents of hsI. ad¬ 
dresses 0100 and 0101, into the accumulator. 


2. If any instruction which requires a reference to 
electrostatic memory during its execution is received, 
and has a negative odd address, the execution refer¬ 
ence to electrostatic storage is to ks2, in the form of 
a full word. For example : 

— radi) 0101 introduces the contents of ks 2, ad¬ 
dresses 0100 and 0101, into the accumulator. 


3. If the instruction extract is received with a 
negative even address, the extract function is per¬ 


formed between the contents of the accumulator and 
the full-word address of Ksl. for example: 


extract 0100 performs the extract function be¬ 
tween the accumulator and the contents of es 1,| 
addresses 0100 and 0101. 

4. Tf the instruction extract is received with a| 
negative odd address, the extract function is per¬ 
formed between the contents of the accumulator and 
the full-word address of i-:s2. For example: 

extract 0101 performs the extract function be¬ 
tween the accumulator and the contents of es 2, 
addresses 0100 and 0101. 

5. If the instruction + sense 0400 is given, all! 
future instructions with positive addresses which re-| 
quire a memory reference for execution will perform 
execution references to esI in the form of a half word. 
For example: 


0000 + sex. si 

: 0400 


0001 + RADI) 

0100 

(The contents of i-:sl, 
address 0100) 

0002 + ADD 

0101 

(The contents of esI , 
address 0101) 

6. If the ins 

traction — 

sexse 0400 is given, all 

future instructions with po 

sitive addresses which re- 

quire a memory 

reference for execution will perform 

execution references to es2. 

For example: 

+ 

^ 1 
o 
o 
o 

0101 

(The contents of i-'.sl. 
address 0101. from 7) 

0003 —sexs 

■ 0400 


0004 +RADD 

0100 

(The contents of es2. 
address 0100) 

0005 + ADD 

0101 

(The contents of es2. 
address 0101 ) 


7. The execution of either a stop or tk instruction 
with a positive address causes all future instructions 
to be introduced from icsl. I'or example: 

0100 Assume the loca¬ 
tion of add to 


0000 (f.s2) —ADD 


he address 0000. 


0000 ( ks2 ) +tr 


0050 


Instruction re¬ 
ceived from ad¬ 
dress 0001 in 


0050 (esI ) —radi) 0100 Instruction re¬ 
ceived from ad¬ 
dress 0050, icsl. 

rite execution of either a stop or tr instruc 
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ADDRESS SYSTEM 


ived with a I 


function he- 0000 —add 0100 (Assume the location of 

cn‘ ' of i-;s 1, add to be address 0000, 

ESl ) 

ived with a 0001 — TR 0050 (Instruction received from 

■tin- i s per- address 0001, esI ) 

mr tor and 0050 — rado 0100 (Instruction received from 

| e; address 0050, es2) 

fur ion he- 

•en of ks2 9. Normal instruction sequence is within a given 
electrostatic unit as follows: 

: s ven all (+4095) esI is followed sequentially by (—0000) 

I - h re esI. 

■ ]1 ^ (+4095 ) es 2 is followed sequentially by (—0000) 

", °T es2. 
a r It word. 
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10. The conditional transfer instructions (±tr 
ov, ± tr +, ±tr 0) refer to the same electrostatic 
storage unit as the location of the instruction. For 
example: 

2346 ±tr+ 4094 (If the location of the instruction 
tr + is in F.sl and if the conditional transfer is 
effected, the next instruction location will be 
4094 of esI. If the conditional transfer is not 
effected, the next instruction location will be 
2347 of esI). 

2346±tr+ 4094 (Same as above with esI replaced 
by es2). 

11. Normal reset and clear, reset, or load 
preselects operation from esI. 

12. The manual light used with single electro¬ 
static storage operation is used as the select light 
for es2 on double storage operation, and is labeled 
“es2.” 

13. A rotary switch is included for the following- 
purposes : 

Position 1. Logical esI operation directed to physi¬ 
cal esI. Logical es2 operation directed to physi¬ 
cal es2. 

Position 2. Logical esI operation directed to 
physical es2. Logical es2 operation directed to 
physical es 1. 

Position 3. Single electrostatic unit operation using- 
physical esI only. 

Position 4. Single electrostatic unit operation using 
physical es2 only. 


Magnetic Drums 

As mentioned before, there are four magnetic 
drums on which information can be stored. Each 
drum is capable of storing 2048 full words of infor¬ 
mation. Each full word on a drum is identified by a 
system of addresses analogous to the system used for 
electrostatic memory, except that there is no provision 
for recognizing half-words. Thus, information must 
be used or stored on a drum in units of full words. An 
address of —1962 may then refer to the full word 
stored in location 1962 in electrostatic storage or 
any one of the four drums. This address usually 
refers to a location in electrostatic storage. An ad¬ 
dress will refer to a drum location only under specific 
conditions. These conditions are described under 
Input-Output Components. 

Magnetic Tapes 

Information is recorded on magnetic tapes in 
blocks of full words. The size of this block of words 
is optional with the programmer and is limited only 
by the length of the tape itself. A series of these blocks 
is said to compose a file of information. Bv pro¬ 
gramming we can locate any particular full word in 
any unit record on any one of the four tapes. Usually, 
however, we are interested in obtaining a complete 
record, or even an entire file, at one time. 

There is no way by which an address can be made 
to refer automatically to a particular location on tape, 
as was possible both in electrostatic storage and on 
the drums. This is because we normally use magnetic 
tapes to store a complete block of information at one 
time. If we want to refer to a particular word among 
a block of words, it is usually best to use the drum 
storage where this can easily be done. The exact 
method by which words are transferred to and from 
tape is discussed later under Input-Output Compo¬ 
nents. 


COMPONENT IDENTIFICATION 

There are four tape units, four drums, one card 
reader, one printer, and one card punch—all of which 
must be given identifying numbers. These identifving 
numbers are placed in the address part of an instruc¬ 
tion whenever the programmer wants the machine 
to operate one of these units. Table I gives the system 
of addresses. Note in Table I that identifications co- 
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incide with those of certain electrostatic storage loca¬ 
tions. Whether the address part of an instruction 
refers to electrostatic storage or to one of the compo¬ 
nents depends on the operation part. Some operations 
will make no sense if the address is interpreted as an 
electrostatic location ; other operations make no sense 
if the address is interpreted as a component identifi¬ 
cation. Thus, an address is automatically interpreted 
by the machine in the light of what it is asked to do by 
the operation part of the instruction (see Operations). 


Table I 


r 

1 

2 

3 4 

Tape Units 

0256 

0257 

0258 0259 

Drums 

0128 

0129 

0130 0131 

Printer 

0512 



Card Reader 

2048 



Card Punch 

1024 


i 
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COMPUTING 


Calculation is done by directing information to 
the computing section, causing operations to be per¬ 
formed on this information, and by storing the results 
of these operations in the memory. To understand 
these processes, we must first realize that the com¬ 
puting section is composed of three internal registers 
called (1) memory register, (2) accumulator regis¬ 
ter, and (3) multiplier-quotient register. Each of 
these registers is capable of holding a full word. Their 


exact capacities: 

Memory register: 35 bits and sign 

Accumulator register: 37 bits and sign 
MO register: 35 bits and sign 

(The two extra positions of the accumulator register, 
called the overflow positions of this register, will be 
explained later; these positions are designated as 
P and 0.) Figure 2 shows a schematic representation 
of these registers. 
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Figure 2 
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3. If an instruction calls for the right half-word o 
a full word, positions 19 through 35 of the full word 
are transmitted to the left half of the memory register. 
If there is a binary digit of 1 or 0 in the 18th position 
of the electrostatic location, the right half-word i< 
recognized in the memory register as negative or 
positive, respectively. The 18 rightmost positions oj 
the memory register are set to zero. 

Once the 


Electrostatic Storage 


Memory Register 


Accumulator Register 


MQ Register 


Figure 3 


ord is in the memory register, it is a 
simple step for the word to be transmitted, bit for bit, 
to either the accumulator register or multiplier-quo¬ 
tient register. The programmer does not have to 
concern himself with the fact that the memory regis¬ 
ter is an intermediate step in the flow of words from 
electrostatic memory to the accumulator register or 
mq (multiplier-quotient) register. It is of interest 
here, because at any time during machine calculation 
the operator can display the contents of all three 
registers on the operator’s panel (see Control). For 
example, one instruction tells the machine to transmit 
a word from a given electrostatic location to the mq 
register. Note that this is done with no explicit refer¬ 
ence to the memory register. 

There are also instructions that cause information 
to be transmitted from the accumulator register or 


The flow of information from the electrostatic 
memory to these registers is shown in Figure 3. Note 
that all information must pass through the memory 
register before entering either of the other two regis¬ 
ters. In this flow of information, three cases are to be 
explained (Figure 4) : 

1. If an instruction calls for a full word from elec¬ 
trostatic storage, the word first appears unchanged in 
the memory register before it goes to either of the 
other registers. 

2. If an instruction calls for the left half-word of 
a full word, positions 1 through 17 of the full word 
and the associated sign are transmitted as shown. 
Note particularly that the least significant 18 bits of 
the memory register are set to zeros. 


Full word location in 
electrostatic storage 


Memory Register 


Electrostatic Storage Location 


Electrostatic Storage Location 


Memory Register 


Memory Register 
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MQ register to an electrostatic location. In these cases, 
the memory register plays no part whatsoever. 

When storing a result in a half-word location, only 
the sign and the first 17 bits of the accumulator regis¬ 
ter are stored. The remaining 18 bits on the right of 
the accumulator and the two overflow bits on the left 
are ignored. The same is true when storing the con¬ 
tents of the mq register in a half-word location of 
electrostatic memory. 

Before beginning a discussion of the arithmetic 
operations, it should be stated that all numbers in the 
701 are expressed in the form of a magnitude and a 
sign. The results of any operation performed in the 
computing unit are always returned to this form. 
Results are never expressed as complements. 

In the following paragraphs a description of pos¬ 
sible operations will be stated in general terms. The 
actual methods and instructions necessary for per¬ 
forming these operations are explained later. 

ACCUMULATION 

A schematic representation of the accumulator reg¬ 
ister was given in Figure 2. Note that there are the 
usual 35 positions to accommodate a full word, plus 
two overflow positions. P and 0. Note also that the 
sign is not located to the left of the bits as is done for 
both full and half-words in the electrostatic memory. 
The sign of a register is indicated separately and is 
schematically represented in Figure 2 by the block 
labeled S. 



The accumulator register, together with the basic 
circuits for adding and subtracting, form what will 
be called the “accumulator."' The accumulator is 
capable of adding a number (coming from memory 
via the memory register) to its contents, of subtract¬ 
ing an incoming number from its contents, of shifting 
hs contents right or left, and of resetting itself to 
zero before entering a new word. The contents of the 
accumulator can also be stored in memory. 

Accumulation is performed as follows: 

Suppose, for example, we wish to calculate 


n * 


os 


A B = C 

where A and B may have either sign. A is first placed 
ln accumulator. Then B is called in from memory 
an d is added to the contents of the accumulator. The 
C, remains in the accumulator replacing A. 
ln ally, C can be stored in memory or used for an- 
°ther operation in the accumulator. 


A similar situation arises in subtraction, where the 
number to be subtracted is the one that comes from 
memory. 

It is also possible to add to or subtract from the 
contents of the accumulator the absolute value of a 
number stored in memory, the sign of this number 
being ignored. 


ROUNDING 

When the machine is instructed to round, the process 
is as follows: 

If a 1 is in the first position of the mq register, the 
contents of the accumulator are increased by a 1 
in the 35th position. If a zero is in the first posi¬ 
tion of the mq register, the contents of the ac¬ 
cumulator are unchanged. In either case the con¬ 
tents of the mq register are unchanged. 

Thus it will be seen how the rounding process, in 
conjunction with a shifting process to be described 
later, enables the programmer to round and truncate 
a number to any desired number of bits. 


MULTIPLICATION 

Multiplication in the 701 provides for the multipli¬ 
cation of two 35 bit factors to produce a maximum 
size product of 70 bits in one operation. 

To multiply A X B. we first must place the multi¬ 
plier, A, in the mq register. Then we simply call out B 
from memory and, at the same time, tell the machine 
to multiply. After the multiplication is complete, the 
most significant bits of the product are found in the 
accumulator, while the least significant bits are placed 
in the mq. It should be noted that before any multi¬ 
plication begins, the accumulator is automatically 
reset to zero. Also, the number in the mq register is 
destroyed during the multiplication process. Both of 
these features are necessitated by the way in which 
the machine multiplies internally. Thus, it is seen 
that cumulative multiplication cannot take place in 
the accumulator, but the summation is very easily 
programmed. 

Placing of the binary point in the factors is com¬ 
pletely arbitrary. A simple familiar rule to remember 
with regard to placing the binary point in the result¬ 
ing product follows: 
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Rule : Add the number of binary bits to the 
right of the binary point in each factor. This 
sum is the number of bits appearing to the 
right of the binary point in the product as 
defined above. 

We can also tell the machine to multiply and round 
in one operation. In this case, an ordinary multipli¬ 
cation is followed by the rounding process. The result 
is a rounded product of 35 bits at most in the ac¬ 
cumulator. 

DIVISION 

Just as multiplication may result in a 70 bit product, 
so division may start with a 70 bit dividend. (Actu¬ 
ally there is a 72 bit dividend since the 0 and P bits 
are considered to be part of the dividend. However, 
unless the 0 and P bits are both zero, a divide check 
light turns on and the machine stops because the divi¬ 
dend is larger than or equal to the divisor in absolute 
value.) The more significant half of the dividend is 
placed in the accumulator, and the less significant half 
is put into the mo register. The divisor is called in 
from memory, and the machine is instructed to divide. 

The quotient is developed in the mq register, dis¬ 
placing the part of the dividend which was in that 
register. After the division, the accumulator contains 
the remainder. This remainder has the same sign as 
the dividend. Preservation of this remainder makes 
double precision division particularly convenient. 

If only a full-sized 35-bit dividend is available, we 
may want to reset the mq register to zero before 
division, because the contents of this register are con¬ 
sidered to be part of the dividend. The magnitude of 
the number in the mq register, in relation to the 
accumulator, however, is less than one in the 35th 
position of the accumulator. If this error is not toler¬ 
able, we must remember to reset the mq register to 
zero before division. 

These properties of the mq register may be used 
conveniently to obtain a rounded quotient. With a 
35-bit dividend the procedure is: 

1. Place the divisor in the accumulator. 

2. Shift it 36 places to the right into the mq regis¬ 
ter, so that one-half the value of the divisor 
appears in the mq register. 

3. Place the dividend in the accumulator. 

4. Divide. 

The resultant quotient in the mq register is then 
properly rounded to 35 bits. If a 70-bit dividend is to 
be used, the absolute value of the less-significant half 


must first be increased by one-half the absolute value 
of the divisor before shifting into the mq register. 

The effect of this procedure is the same as if a 
36-bit quotient had first been developed, a 1 had been 
added to the 36th bit, and this bit had been dropped 
after any carries had been propagated. 

As in multiplication, something must be said with 
regard to where the binary point is assumed to be in 
division. What will be called the “standard” case will 
be stated first followed by two rules necessarv to de¬ 
termine the location of the binary point in any other 
case. The machine will perform division onlv if the 
divisor is larger than the dividend as defined below. 

“Standard” Case. Assume that the binary point 
of the dividend is located between the 35th posi¬ 
tion of the accumulator and the first position ol 
the mq register. Also assume that the divisor 
being called in from memory has its binary 
point located to the right of the 35th position 
[ Caution : If, zvith the binary points assumed 
to be in these positions, the dividend is larger 
than or equal to the divisor tin absolute value), 
the machine will stop, and a di-vision check light 
will turn on to warn the operator.) With these 
assumptions,-the 35-bit quotient developed in the 
mq register will have its point located to the 
left of the first position. The remainder, if any, 
which is developed in the accumulator, has its 
binary point located between positions P and 1. 

The following rules are based on changes of the 
binary points from the standard case. 


Rule 1 : A change in the binary point of the 
dividend results in a change equal in magni¬ 
tude and in the same direction in the points 
of both the quotient and remainder. 

Rule 2: A change in the point of the divisor 
results in a corresponding change in the oppo- ■ 
site direction of the point of the quotient. The 
point of the remainder is unchanged. 

SHIFTING 

Shifting is a process by which the binary bits of a 
word may be moved to the right or left with respect 
to the positions of a register in the computing section. 
There have been references to these paragraphs in 
previous sections as a means of programming calcu¬ 
lations so that the binary point may be arbitrarily 
located at the discretion of the programmer. 
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Figure 5 


Two kinds of shifts are possible : 

Accumulator Shift. The 37 bits that may be 
standing in the accumulator register' can be 
shifted one or more places, either to the right or 
left. Digits shifted beyond the capacity of the 
register are lost. Vacated positions are filled with 
zeros. 

Long Shift. Both the multiplier-quotient register 
and the accumulator take part in the long shift. 
They behave as if the mq register were con¬ 
nected to the right of the accumulator as shown 
schematically in Figure 5. For instance, a long 
right shift by 69 places causes the bit in position 
1 of the accumulator to be shifted all the way 
over to position 35 in the mq register, the inter¬ 
vening bits having dropped off the end. The 
process is similar for a long left shift. On a long 
right shift the sign of the mq register is changed 
to the sign of the accumulator register. On a 
long left shift, the sign of the accumulator regis¬ 
ter is changed to the sign of the mq register. 
A useful device is to specify a long shift of zero 
places which produces no actual shift but merely 
changes the sign of the mq register or the ac¬ 
cumulator as described above. 

If the shift is far enough, with either the accumula¬ 
tor shift or the long shift, nothing will be left but 
zeros. Thus, shifting may be used to reset the ac¬ 
cumulator or mq register to zero. For convenience 
in certain programs, such as floating-point calcula¬ 
tions, we can specify a shift of as many as 255 places 
in a single operation, although only zeros are pro¬ 
duced by long shifts in excess of 71 places. However, 
no provisions have been made for permitting shifts 
by more than 255 places. An attempted shift of more 
than 255 places gives the results described under 
operations. 

It should be noted that the overflow positions of 
the accumulator participate in both kinds of shift. The 
Sl t> ns of the registers, however, do not participate in 
t 1e s hift except as specifically noted above. 


SIGN OF ZERO 

It is possible for a zero in this calculator to have 
either a plus or a minus sign. For instance, a negative 
number in the accumulator may be shifted so far to 
the right or left that all numerical bits are zeros. This 
still leaves the minus sign, so that technically the 
result is "—0". Arithmetic operations may also result 
in zeros of either sign. The arithmetic circuits are 
designed so that if the result of an addition or sub¬ 
traction is zero, the sign of the result will be that of 
the number which was in the accumulator immedi¬ 
ately before the addition or subtraction took place. 
In numerical work no distinction need be made be¬ 
tween a —0 and a —0 result, because either zero can 
be used in further arithmetic operations. 

This characteristic of the machine is sometimes 
very convenient; there are ways the machine can be 
made to recognize either type of zero. It is also pos¬ 
sible for the machine to ignore the sign entirelv and 
test to see only if the result is zero. Such controls are 
discussed in a following section. 

OVERFLOW INDICATION 

This section covers the accumulator overflow posi¬ 
tions, P and 0. 

During such operations as adding, subtracting, and 
shifting left, it is possible for non-zero binary bits to 
enter into or be shifted completely through the over¬ 
flow positions of the accumulator. This can happen 
by means of a left shift or as the result of a carrv in 
addition or subtraction. Whenever a non-zero binary 
bit enters position P from position 1, an overflow 
indicator within the machine is turned on. Associated 
with the activation of this indicator is an overflow 
light on the operator's panel. This overflow indication 
occurs even in a shift that sends a binary bit com¬ 
pletely through the overflow positions. Overflow may 
indicate an error in setting up the program for 
a given set of data. Frequently, however, operations 
are planned deliberately to produce overflow. Hence, 
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the machine will continue to operate after an over¬ 
flow, but an instruction is available to test the con¬ 
dition of the overflow indicator and to program the 
desired action after an overflow. This may include 
stopping the machine on overflow, performing a spe¬ 
cial set of operations, or simply ignoring overflow. 
Testing the overflow indicator turns it off. 

Examples of the operation of the overflow indi¬ 
cator follow. In these examples we assume the binary 
point to be to the left of position 1. For convenience 
and abbreviation only the first three bits to the right 
of the binary point are shown. 

In the addition 

OVERFLOW POSITIONS 

+.100 +00.110 = +01.010 

WORD FROM MEMORY ACCUMULATOR ACCUMULATOR 

there is a carry that produces an overflow and causes 
the overflow light to go on. If now the indicator is 
turned off (by use of the test instruction) and a sec¬ 
ond addition 

+.100 + 01.010 = +01.110 

is performed, the overflow indicator does not come 


on again, because there was no carry past the binar 
point this time. A further addition 

+.100 + 01.110 = +10.010 
again gives an overflow indication, because a carr 
was propagated through the binary point. 

If shifts or carries go beyond Q, the excess bits ar 
dropped. Thus +00.010 shifted left by two places it 
the accumulator gives +01.000 with an overflow 
But if +00.010 is shifted left by four places, the resul 
is +00.000, again with an overflow indication. In th 
first case, the process may be reversed by shiftinj 
right, but in the second case, bit 1 has been lost, am 
any shifting to the right still gives a zero result. 

The extra two bits in the accumulator enable th 
programmer to make full use of the 35 numerical bit 
in memory for such operations as double-precisioi 
arithmetic. When a possible overflow must be allowei 
for in a program, the extra bits make it considerabl 
easier to shift and return the result to a standari 
form. 

The overflow bits do not enter into multiplication 
because the product of two 35-bit numbers canno 
exceed 70 bits. Neither can they be part of a dividend 
because the dividend cannot be greater than th 
divisor as defined earlier in the “standard" case. 
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counter known as the instruction counter, which con¬ 
tains the address of the instruction currently being 
executed. After each execution, the number in this 
counter is automatically increased by 1. Consequently, 
the machine will automatically take its next instruc¬ 
tion from a location whose half-word address is one 
higher than the address from which the current in¬ 
struction was obtained. In this way the machine con¬ 
tinues to execute instructions in the sequence in which 
they were stored in memory. 

This normal sequence of instructions can be altered 
by means of certain “transfer” operations to be ex¬ 
plained below. By means of these operations, any 
half-word location in electrostatic storage can be 
designated as the source of the next instruction. The 
address of this location is placed in the instruction 
counter by the transfer instruction; thereafter, execu¬ 
tion of the program again proceeds sequentially. 

An important observation with regard to this 
stored-program technique should be noted. Instruc¬ 
tions are stored in the machine just like numerical 
data; the only distinction between the two is the way 
in which they are interpreted by the machine. If for 
any reason the address of a half-word of data is 
entered into the program counter, the data will be 
interpreted as an instruction. Conversely, an instruc¬ 
tion may be caused to enter the computing unit just 
as data are caused to enter the computing unit. Thus, 
one instruction may call for the modification of an¬ 
other instruction by directing the machine to compute 
a new address part or to substitute another operation 
part. One program may operate on itself and com¬ 
pute one of its own instructions. A program may 
choose between several alternatives, depending on 
results obtained in the course of the problem. The 
ability of the machine to modify and to relocate in¬ 
structions at high speed lends great flexibility to its 
operation and enlarges the scope of its application. 

Instruction Layout 

Each operation the machine can execute—includ¬ 
ing arithmetic operations, shifting, rounding, read¬ 
ing, writing, and others—is assigned a numerical 
code. An operation in conjunction with the address 
of an appropriate operand constitutes an instruction 
and is written and stored as a single binary number. 
The two components of an instruction are referred 
to as the operation part and the address part. A sche¬ 
matic diagram of an instruction is shown in Figure 6. 
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Operation 

Part 

Address Part 
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Figure 6 

Note that the 17 bits of information and associated 

sign require exactly a half-word of storage space. 

\ 

The operation part of an instruction determines 
the nature of the operation the machine is to execute. 
The numerical code for the operation is located in 
positions 1 through 5 of the instruction itself. The 
701 is capable of performing exactly 32 distinct oper¬ 
ations divided into four categories: (1) arithmetic 
operations, (2) logical operations, (3) input-output 
operations, (4) sense operations. These operations 
will be explained in detail later. 

The address part of an instruction specifies a num¬ 
ber that usually refers to a location in electrostatic 
storage. In such cases, the address will be a positive 
or negative integer as defined previously under 
Address System. The sign of the integer in positions 
6 through 17 of the instruction is determined by the 
sign of the instruction itself. Thus, the sign of an 
instruction applies only to the address part. For some 
instructions, however, the address part designates a 
certain input-output unit; with shift instructions it 
indicates the number of places to be shifted. But the 
name “address part” for the 12 rightmost bits of an 
instruction is retained, although these bits do not 
always represent an address in the true sense of the 
word. It will be seen later that the sign of some in¬ 
structions is immaterial. 

The machine interprets the numbers in the opera¬ 
tion part and the address part as integers. In other 
words, the binary point of the binary digits occupy¬ 
ing positions 1 through 5 is considered to be imme¬ 
diately to the right of position 5. Similarly, the binary 
point of the digits occupying the address part is con¬ 
sidered to be immediately to the right of position 17. 

For example, an instruction which designates 05 
as the operation and —0013 as the address, will ac¬ 
tually look in binary form as follows : 

OPERATION PART ADDRESS PART 

-00101000000*001 lof 
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OPERATOR’S PANEL 

The various buttons, keys, switches, and signal 
lights by means of which the operator can control and 
communicate with the machine are assembled to form 
the operator’s panel. The only control panels on the 
machine which require wiring are those for the card 
reader, printer, and card punch. These panels are dis¬ 
cussed later in a separate section. 
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Description of the Panel 

Components of the operator's panel are listed below 
with a brief explanation of their functions. Some of 
these functions will not be completely understood 
without reading later sections. 

Power-On Button. Turns on the power for the 
entire calculator and automatically performs the re¬ 
setting functions of the reset and dear-memory 
button. 
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Power-Off Button. Turns off the power for the 
entire calculator immediately, but leaves the blowers 
on for 10 minutes. 

DC-Off Button. Turns off the direct-current power 
for servicing the machine. 

DC-On Button. Turns the direct-current power on 
after it has been turned off with the DC-off button. 

Power-On Light. Indicates that the main AC 
power is on. 

Ready Light. Indicates that the AC and DC power 
is on and that the calculator is stopped but is ready 
to run. W hen the power is turned on, there is a delay 
before the ready light comes on. 
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Operating Light. Indicates that the calculator is 
running. When the calculator is started, the operat- 
ing light goes on and the ready light goes off. When 
the calculator stops, the operating light goes off and 
the ready light goes on, if the power is still on. 

Automatic-Manual Switch. When this switch is 
se t to automatic, the calculator may be operated at 
full speed. W hen it is set to manual, the calculator 
may be operated manually by means of the half-step 
and multiple-step keys and the enter mq, enter in¬ 
struction, and memory display buttons; the load 
utton is inoperative, and the start button cannot 
st art the calculator. The calculator cannot be ad- 
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vanced manually while the stored program is using 
any input-output device. 

Manual Light. Goes on when the automatic-man¬ 
ual switch is set to manual. 

Start Button. If the automatic-manual switch is 
set to automatic, the start button resets the various 
machine interlocks and then starts the calculator. The 
program begins with the instruction whose address 
is contained in the instruction counter. 

Reset Button. Resets the accumulator, mq and 
memory registers, the instruction counter as well as 
certain internal input-output and check interlocks 
which are not discussed in this manual. It does not 
affect electrostatic storage. 

Reset and Clear-Memory Button. Changes every 
bit in electrostatic storage to a 1 and, in addition, 
performs certain resetting functions not discussed in 
this manual. 8. 


Register Lights. Groups of small neon lights that 
indicate the contents of the following registers: 
Memory register 
Accumulator register 


MO register 
Instruction counter 
Instruction register 
(a) Sign register 
(.b) Operation-part register 
(c) Address-part register 

A light being on indicates a binary digit of 1 located 
in that position of the register. A light being off indi¬ 
cates a zero. 


MQ-Entry Keys. These 18 keys are used to set up 
a half-word for manual entry into the mq register. 
Depressing a key represents a binary 1. 


Enter-MQ Button. If the automatic-manual switch 
is set to MANUAL, the enter-MQ button enters the half¬ 
word set up on the 18 MQ-entry keys in the left 18 
positions of the mq register. The rightmost 18 posi¬ 
tions of the mq register are reset to zero. 

Instruction-Entry Keys. There are 18 instruction 
entry keys, consisting of a sign-entry key, five opera¬ 
tion-part entry keys, and twelve address-part entry 
keys. They are used to set up instructions for manual 
entry of an instruction into the control section of the 
calculator. 
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Enter-Instruction Button. If the automatic-manual 
switch is set to manual, the enter instruction button 
enters the instruction set up on the instruction entry 
keys into the instruction register and causes this in¬ 
struction to be executed. The calculator then stops. 
Instructions, pertaining to input-output devices which 
must follow each other at high speed, cannot be 
executed manually with the enter instruction button. 
If the stored program calls on an input-output device 
which must receive its instructions in rapid succes¬ 
sion, the calculator will automatically go into high¬ 
speed operation until this section of the program is 
completed. 

Memory-Display Button. If the automatic-manual 
switch is set to manual, the memory-display button 
causes the full word stored at the address set up on 
the address part of the instruction-entry keys to be 
displayed on the memory-register lights. Only full 
words are displayed in this way. 

Half-Step Key. If the automatic-manual switch is 
set to manual, the half-step key advances the program 
one half-step at a time, provided the machine inter¬ 
locks do not prevent the advance of the program. 
Half-steps are of two kinds: interpretation half-step, 
during which an instruction is interpreted, and execu¬ 
tion half-step, during which the instruction is exe¬ 
cuted. Repeatedly pressing the half-step key causes 
the calculator to alternate between interpreting and 
executing an instruction. If a read or write instruc¬ 
tion is executed, the calculator will go into automatic 
operation until the stored program is through using 
the particular input-output unit selected by the read 
or write instruction. 

Multiple-Step Key. Holding down the multiple- 
step key is equivalent to pressing the half-step key 
repeatedly about ten times a second. Releasing the 
multiple-step key stops this action. 

Machine Cycle Button. Advances the program one 
machine cycle at a time. It is intended only for servic¬ 
ing the machine and is not used by the operator. The 
half-step or multiple-step keys should be used to ad¬ 
vance a program manually. 

Load Selector Switch. Selects either the card 
reader, or the first tape unit (address 0256), or the 
first drum unit (address 0128), from which a unit 
record is to be read bv means of the load button. 
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Load Button. If the automatic-manual switch is se| 
to automatic, the load button initiates the reading 
a unit record from the input unit selected by the loai| 
selector switch. It causes the first full word of the 
record to be read and to be stored at the address sd 
up on the address-part entry keys. The calculator the| 
starts automatically, using as the first instruction 
left half-word at the same address. Pressing the loa< 
button is in effect the same as giving the followin' 
instructions: 
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:ias s’ 
Jthe w 
Ireset 


READ 


SET DR 0000 
COPY 


TR 


(Address of input-output unit 
specified by load selector) 
(Relevant for drum only) 
(Address set up on address-par] 
entry keys) 

(Address set up on address-par| 
entry keys) 


Pn 

as s' 
ion. - 
r tht 


Ta 

has s' 
couni 
read, 
butto 


Di 

has s 
divisi 


Thus it is seen that the calculator will go into auto 
matic operation starting with the instruction locate 
at the address set up on the instruction entry keys 

Sense-Input Switches. There are 6 two-positio; 
sense-input switches, identified by addresses 0069 ti 
0074. They can be sensed by means of a sense in 
struction with the corresponding address part am 
used to cause the calculator to skip an instruction. 

Sense-Output Lights. These four lights may k 
turned on individually by means of sense instruc 
tions, as explained above. Another sense instruction 
turns all four off together. The lights are used by thi 
programmer to indicate the progress of a problen 
and to signal various conditions. 


butto 

Cc 

main 
tape 
of th' 
reset 

In, 

burn' 

repla 

butte 

mem 

Basi 


Instruction-Time Light. For halt-step operation 
this light indicates that the calculator is ready to pel 
form the next interpretation half-step. 


In 
static 
at a 


Execution-Time Light. For half-step operation thi 
light indicates that the calculator is ready to perforn 
the next execution half-step. 


Overflow Light. Turns on when the overflow indi 
cator turns on. It is turned off by execution of • 
tr ov instruction or by the reset and clear-memor; 
button. 

Input-Output Light. Indicates that one of th< 
input-output units is selected by the calculator. 


: 
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Program-Stop Light. Indicates that the calculator 
ohas stopped as a result of executing a stop instruc¬ 
tion. It is reset by the start button, or the reset button, 
r the reset and clear-memory button. 


ess g the 
; tf follow 


ln | 


-oi >ut unit 
ad ..elector) 
m only) 

■n ; dress-pai 


Tape-Check Light. Indicates that the calculator 
|ias stopped because of a discrepancy in the tape group 
ount or the redundancy check while a tape was being 
ead. It is reset by the start button, or the reset 
hut ton, or the reset and clear-memory button. 


'ii address-pan 


i go into autc 
rue.'on locate! 
on ntrv kev 


Divide-Check Light. Indicates that the calculator 
Jias stopped because the dividend is not less than the 
ivisor. It is reset by the start button or the reset 
'button, or the reset and clear-memorv button. 
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Copy-Check Light. Indicates that the calculator 
[las stopped because a copy instruction was given at 
he wrong time. It is reset by the start button, or the 
eset button, or the reset and clear-memory button. 


Calculator-Fuse Light. Indicates that a fuse for the 
jiiain calculator unit, or electrostatic storage, or a 
:ape or drum unit has burned out. After replacement 

f f the fuse, the light is reset by the start button or the 
eset button, or the reset and clear-memory button. 

Input-Output Fuse Light. Indicates that a fuse has 
mrned out in the card reader, punch, or printer. After 
■eplacement of the fuse, the light is reset by the start 
mtton or the reset button, or the reset and clear- 
nemory button. 


;[ |Bas/c Manipulations 

Entering Information into Storage 
Information may be entered manually into electro¬ 
nic storage from the operator's panel one half-word 
a time. The procedure : 


1. Set up the automatic-manual switch to manual. 

2. Set up the half-word on the MQ-entry keys. 

3. Set up the instruction + store mq xxxx on 
the instruction entry keys, where xxxx repre¬ 
sents the address (in binary form) at which the 
half-word is to be stored. 

4. Press the enter-MQ button to enter the half¬ 
word into the mq register. 

5. Press the enter-instruction button to execute 
the instruction (set up under 3), thus storing 
the half-word in memory. 

6. Press the memory-display button to check that 
the half-word has been stored correctly. 

A full word can be entered into electrostatic stor¬ 
age from the operator's panel only by splitting it into 
two half-words and entering each separately. 

Starting Machine with a Given Instruction 

Assume the operator wants the machine to begin 
calculating with an instruction located in address 
xxxx of electrostatic memory. 

1. Set automatic-manual switch to manual. 

2. Set up the instruction transfer xxxx on the 
instruction entry keys. 

3. Press the enter-instruction button. 

4. Set automatic-manual switch to automatic. 

5. Press the start button. 

If there is a program stored in memory, the ma¬ 
chine will start calculating with the instruction located 
at xxxx and continue automatically. 


op ation thi 
idy to perfori 

ovviflow ind 
.execution of 
cli --memo! 


:t ■ le of tli 
dci tor. 









_ _ __ . 



OPERATIONS 




All operation's of which the machine is capable will 
be explained in this section. For the sake of reference 
purposes and completeness, some operations will be 
discussed that will not attain their full significance 
until later sections are studied. 

Operations are grouped under the general classifi¬ 
cations of arithmetic operations, logical operations, 
input-output operations, and sense operations. Asso¬ 
ciated with each individual operation is a heading for 
its explanatory paragraphs. An example of such a 


heading: 


Reset and Add 


10-1, 2, 3, 4 


This heading has the following meaning: first is the 
name of the operation; the term in the second line is 
the abbreviation commonly used for the operation; 
the numerical code for the operation then appears on 
the third line followed by a dash and numbers of the 
examples in Part II that illustrate the operation by 
means of a simple program. If the word “none” ap¬ 
pears after the numerical code, it means that the 
operation is either explained fully in other sections or 
needs no further explanation. 


Moreover, each operation is assumed to refer to 
the address part .r of some instruction, where .r in¬ 
cludes the sign of the instruction. The contents of 
electrostatic location x are never changed except as 
specifically stated. A half-word comes from memory 
into the memory register, and finally into the other 
registers, as described under Computing. 

A complete list of all 33 operations, together with 
their numerical code, is given in Summary of Ma¬ 
chine Characteristics. 

ARITHMETIC OPERATIONS 

Operations are grouped in this classification if they 
take place in the computing section. They include the 
ordinary arithmetic functions, shift instructions and 
store instructions. 

Reset and Add Contents of the accumulator register 
R add are replaced by contents of electrostatic 

io-i, 2, 3, 4 location .r. 


The number in electrostatic location x is regie 
added to the number in the accumulator niul a 


09-i, 2, 4, 10 register. 
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Add Absolute Value The absolute value of the number 
add ab in electrostatic location x is added 

n-3 to the contents of the accumulator. 

Reset and Subtract Contents of the accumulator regis- 
r sub ter are replaced by the negative of 

06 - 2,12 the contents of electrostatic loca¬ 

tion x. 

Subtract The number in electrostatic location nr is 
sub subtracted from the number in the accu- 

05 - 2 , 11,12 mulator register. 

Subtract Absolute Value The absolute value of the 
sub ab number in electrostatic loca- 

07-3 tion .r is subtracted from the 

number in the accumulator. 

Store The contents of electrostatic location .r are 
store replaced by the contents of the accumulator 
12 - 1 , 2 ,3 register, exclusive of the two overflow posi¬ 
tions. \\ hen a full-word location is specified by the 
address x, the sign and the 35 bits to the right of the 
overflow positions of the accumulator are stored in 
the memory location. \\ hen a half-word address is 
specified, the sign and the bits in positions 1 through 
17 of the accumulator are stored in the half-word 
memory location. The contents of the accumulator 
are not changed. 

Store Number in MQ Register The contents of electro- 

ST0REMQ static location x are re- 

14—7 

placed by the contents of 
the mq register. When a full-word address is speci¬ 
fied, the entire contents of the mq register, including 
Sl gn, are stored in the memory location. When a half¬ 
word address is given, the leftmost 17 bits in the mq 
register and the sign are stored in the half-word 
lemory location. Contents of the mq register are 

unchanged. 

Load MQ Register Contents of the mq register are 
,, „ replaced by contents of electro- 

'"* 5 , 6 8 11 

' ' static location .r. 


Round 
ROUND 
W-3, 6, 8 


The magnitude of the number in the accu¬ 
mulator register is increased by a one in 
position 35 if the bit in position 1 of the mq 
register is a one. Otherwise the contents of the accu- 
ator register are unchanged. In any case, the mq 
glste r remains unchanged. 


Multiply The accumulator register is first reset to 
MPY zero. Then the number in electrostatic loca- 
16-6 tion x is multiplied by the number in the mq 
register. The most significant 35 bits of the product 
are produced in the accumulator; the least significant 
35 bits are produced in the mq register. Both registers 
have the sign of the product as determined by the two 
factors. The multiplicand, from the specified memory 
location, may be either a full-word or a half-word. 
If a half-word is specified, the instruction operates as 
though it were a full-word with 18 zeros on the right. 
The mq register is always considered to contain a 
full-word, even though a half-word had been previ¬ 
ously placed in it. Thus, if a half-word had been put 
into the mq register and multiply were given with 
a half-word address, the product would have 34 sig¬ 
nificant bits and would appear in bit positions 1-34 of 
the accumulator. The remaining bit position 35 of the 
accumulator and the entire mq register would be filled 
with zeros. For integers, a shift left 17 at this point 
gives a half-word product and a shift right 1 gives a 
full-word product. When the product of a negative 
by a positive number is such that either the accumu¬ 
lator part or mq part is all zeros, this zero will have a 
negative sign. Otherwise, a positive zero results. 


Multiply and Round 

MPY ROUND 
17-5 


This instruction produces the 
same result as a mpy instruction 
followed by a round instruction. 


Divide The possible 70-bit dividend placed in the ac- 
div cumulator and mq registers is divided by the 
18-7, 8 number contained in electrostatic location x. 
The quotient with proper sign appears in the mq 
register. The remainder, if any, is developed in the 
accumulator and has the same sign as the dividend. 
The machine treats that part of the dividend placed 
in the mq register as if it had the same sign as the 
accumulator. Half-word divisors behave as full-words 
with the rightmost 18 bits zero. If the divisor is not 
greater than the dividend, as previously defined, the 
machine stops, and the div check light is turned on. 

Note : In all of the shift instructions that follow, 
the address x specifies the number of places to be 
shifted. The machine will recognize any number from 
0 to 255 inclusive for this shift. If x is greater than 
255, the actual number of places shifted is the differ¬ 
ence between the given number, and the nearest inte¬ 
gral multiple of 256 which is less than or equal to the 
given number. In other words, the number of places 
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shifted is x, modulo 256. For example, if x = 258, the 
extent of the shift will be two places. If x = 512, this 
is equivalent to giving the shift instruction with 
x = 0. Shifts up to 255 are permitted for convenience 
in certain uses of the machine such as floating-point 
programs. 


Accumulator Right Shift The contents of the accumula- 
a right tor register (not including the 

23-4 ' 11 sign) are shifted right by x 

places. Emptied positions are filled with zeros. Bits 
shifted past position 35 are lost. Both overflow posi¬ 
tions participate in the shift. (See note above.) 

Accumulator Left Shift The contents of the accumula- 
a left tor register (not including the 

22-1 ' 4 ' 8 sign) are shifted left by x 

places. Emptied positions are filled with zeros. If a 
non-zero bit is shifted from position 1 into position P 
at any time during the shifting operation, the over¬ 
flow indicator is turned on. Bits shifted beyond the 
leftmost overflow position are dropped. (See note 
above.) 

Long Right Shift The contents of the accumulator and 
l right the mq register are considered as one 

21 - 3 , 7,11 number (not including signs') and 

are shifted right by x places. Bits shifted out of the 
accumulator appear at the left of the mq register. For 
example, a bit initially occupying position 35 of the 
accumulator finally occupies position 1 of the mo reg¬ 
ister on a long right shift of one. The sign of the mq 
register is changed to agree with the sign of the accu¬ 
mulator register. (See note above.) 

Long Left Shift The contents of the accumulator and 
l left the mq register (not including signs) 

20 - 6 , 8, li are shifted left by .r places. Bits shifted 
out of the mq register appear at the right of the accu¬ 
mulator register in the opposite manner as described 
under Long Right Shift above. The sign of the accu¬ 
mulator register is changed to agree with the sign of 
the mq register. If a non-zero bit is shifted from posi¬ 
tion 1 to position P of the accumulator register at any 
time during the shifting operation, the overflow indi¬ 
cator is turned on. (See note above.) 


LOGICAL OPERATIONS 

Axy operation which may be used to alter self 
tively the course of a program is considered umj 
this category. The address x, as before, is assutn 
to contain the sign of the instruction. The sign of 
instruction in this group is entirely immaterial unit 
specifically mentioned. 

Transfer This instruction causes the machine to ta 
tr its next instruction from electrostatic lot 

oi-3, 9, li tion x. The program then proceeds sequt 
daily from this new instruction. 

Transfer on Plus If the sign of the contents in the; 
tr -f- cumulator register is plus, a trans 

03-9 ,12 takes place exactly as described unt 

Transfer above. If the sign is minus, the transfer 
not executed and the program continues sequential 
The transfer is determined only by the sign of i 
word in the accumulator. Thus, "plus zero'' is; 
garded as a positive word, and "minus zero” 
regarded as negative. 

Transfer on Zero If the contents of the accumula; 
tr o are zero (including the overfli 

04 - 9 , io, li positions) a transfer is effected! 

actly as described under Transfer above. The sign 
the accumulator has no significance. If, howev 
there is a binary 1 in any position of the accumulat 
the transfer does not take place, and the progr; 
continues sequentially. 

Transfer on Overflow If the overflow indicator is 
tr ov as the result of a previous ope: 

02-3 tion, a transfer of control ta! 

place exactly as indicated under Transfer above, a 
the overflow indicator is reset to the off position, 
however, the overflow indicator is not on, no trans 
is effected, and the program continues in its norn 
sequence. 

Stop and Transfer The calculator stops when this 
stop struction is received. When I 

oo-none start button on the operator's pa' 

is pressed, the calculator will start again, beginni 
with the instruction at electrostatic location x a 
will continue sequentially. 

Store Address The rightmost 12 bits of the half-Wt 
store a at electrostatic location x are repla c 

13-10, 12 by the bits in position 6 through l7 

the accumulator register. Note that these positi° 
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represent the address part of an instruction. The re¬ 
maining bits (including the sign) at location x, are 
unchanged. The sign of this instruction must be posi- 


Extracf The sign of this instruction must be minus. 
extr The extractor or “mask” is located any- 

— i 3 -none where in memory. The word from which 
we wish to extract any combination of bits is located 
in the accumulator. The extract order is then given. 
The extraction process (or logical multiplication) 
proceeds from the accumulator into the memory loca¬ 
tion specified by the address part of the extract 
instruction. At the completion of this operation, the 
result of the extraction has replaced the word in 
memory specified by the address part of the extract 
instruction. 

In its simplest form, the extract operation can be 
understood by considering four cases. In each case 
assume corresponding bit positions in the accumu¬ 
lator and in memory. 


Case Condition 

I ZERO in accumulator 
ZERO in memory 

II ZERO in accumulator 
ONE in memory 

III OX E in accumulator 
ZERO in memory 

IV ONE in accumulator 
ONE in memory 


Result 

ZERO in accumulator 
ZERO in memory 

ZERO in accumulator 
ZERO in memory 

ONE in accumulator 
ZERO in memory 

ONE in accumulator 
ONE in memory 
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From the above cases, note that the word in the 
accumulator remains unchanged, while the word in 
memory may change. The result of the extraction, 
therefore, is a word that has ones where both words 
I have ones and zeros in every remaining position. 

The extract order affects all 36 bits of a word; 
that is, the sign bit is treated in the same manner as 
J n >’ °f the other bits. 

The time for obtaining and executing the extract 
operation is the same as that for any STORE-type in¬ 
struction—i.e., 60 microseconds, unless one of the 
Previous 12 instructions was a multiplication, in 
VV ' c ^ case the extract order will require 

microseconds. 


: tl half-vvt Note : By means of the conditional transfers de- 
.r are repla< Scn bed above, it is possible to program a “transfer on 
tb-ough 17 ni >nus” and “transfer on non-zero.” (See Example 9 
he positic ln Part II.) 


INPUT-OUTPUT OPERATIONS 

The operations that follow will not be completely 
understood until the section on Input-Output Compo¬ 
nents has been studied. In fact, the Operations section 
and the Input-Output Components section comple¬ 
ment each other. The sign of these operations is im¬ 
material unless specifically stated otherwise. 

Prepare to Read This instruction causes the calcula¬ 
te 1 tor to prepare to read one unit rec- 

24 ~ none ord of information from an input 

mechanism (component) designated by the address x. 
If the address x identifies a tape unit, the mq register 
is reset to zero. A selected tape unit must be in read 
or neutral status if the instruction is to be effective. 
(See Magnetic Tapes in next section.) 

Prepare to Read Backward This instruction causes the 
READ B calculator to prepare to read 

25_none one unit record of informa¬ 

tion from a tape unit in the backward direction. Thus, 
this instruction makes sense only if x refers to a tape 
unit. The mq register is reset to zero as in the read 
instruction. For the instruction to be effective, the 
selected tape unit must be in read or neutral status. 
(See Magnetic Tapes in next section.) 

Prepare to Write This instruction causes the calcula- 
WRITE tor to prepare to write one unit rec- 

26—none ord of information on an output 

mechanism (component) designated by x. A tape unit 
must be in write or neutral status for this instruction 
to be effective. (See Magnetic Tapes in next section.) 

Write End of File This instruction causes the machine 
WRITE EE to clear a section of the magnetic 

27 ~ none tape unit designated by x. This 

"gap” is then recognized, in any subsequent reading, 
as an end-of-file gap and may be used to control the 
program. The instruction is effective only if the se¬ 
lected tape unit is in a write or neutral status. (See 
Magnetic Tapes in next section.) 


Rewind Tape The tape unit identified by x is rewound 
rewind to its starting point, regardless of the 

28 -none tape status. The rewind, however, causes 

the tape unit to be placed in neutral status. (See Mag¬ 
netic Tapes in next section.) 

Set Drum Address The address x in this instruction 
SET DR specifies the location on the drum 

22-none of the first word of a unit record 

that is to be read or written. It is given following a 
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read or write instruction that selects a drum as the 
input or output mechanism. Not giving a set dr in¬ 
struction is equivalent to giving the instruction with x 
equal to zero. Since only full-word locations may be 
referred to on a drum, the sign of the instruction is 
immaterial. However, x must be one of the even inte¬ 
gers in the range 0000 to 4094. 

Copy and Skip The copy instruction is used follow- 
copy ing the read, the read backward, or 

31-none the write instruction. When copy 

follows read or read b, its execution causes the word 
coming from the input mechanism to be placed in 
memory location x. When copy follows a write in¬ 
struction, the word in memory location x is sent to 
the output mechanism to be written as part of a unit 
record. 

While reading cards or tape, the machine will rec¬ 
ognize the fact that the end of a unit record has been 
reached. If a copy instruction is given subsequent to 
this recognition, the copy will not be executed; in¬ 
stead, the machine will skip to the third instruction 
following the copy instruction, and continue sequen¬ 
tially. This is known as an end-of-record skip. 

Similarly, the machine will recognize that it has 
just completed the last unit record of a file if one 
extra read instruction is supplied. In this case, a 
copy instruction given after the extra read instruc¬ 
tion will not be executed, and the machine will skip 
to the second instruction following the copy instruc¬ 
tion. This is known as an end-of-filc skip. In reading 
from a drum, or writing by means of any output 
device, the copy instruction never causes a skip. 

The mq register is an intermediate step in the 
transmittal of words to or from electrostatic storage. 
Execution of a copy instruction, therefore, destroys 
any number that may have been standing in the mq 
register. In fact, this execution, for all input-output 
mechanisms (except tape), results in the mq register 
containing the word just copied. 

Since the input-output units are capable of handling 
units of full-words only, the copy instruction nor¬ 
mally is given a negative sign. If copy is given with 
a positive sign while a unit record is being written, 
the half-word in the memory location actually speci¬ 
fied by the. copy instruction, will be written as a full- 
zi'ord with zeros in the rightmost 18 bit positions. On 
reading a unit record, copy given with a positive sign 
and an even address will cause the sign and leftmost 
17 bits of the full-zvord being brought in to be stored 
in the half-zvord location actually specified by the 


copy instruction. Copy given with a positive sign and 
an odd address will cause the rightmost 18 bits of the 
full-word being brought in to be stored in the half¬ 
word location specified. Note that this results in the 
most significant part of the number being lost. 

SENSE OPERATIONS 

The name, abbreviation, and numerical code for a 
sense operation follows. The sign of the instruction 
has no significance. 

Sense and Skip or Control 

SENSE 

30—none 

The sense instructions provide a means by which 
electrical signals may be transmitted between the 
automatic control section of the calculator, on the one 
hand, and the printer, card punch, and operator’s 
panel, on the other. The address x of a sense instruc¬ 
tion is used to identify any one of several electrical 
terminals. These terminals are classified as either 
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Table II 


Printer 

Card Punch 

Operator's Pane: 

input 

OUTPUT 

INPUT OUTPUT 

IX PUT 

OUTPUT 

0522 

0512 

none 1024 

0069 

0065 


0513 

1025 

0070 

0066 


0514 


0071 

0067 


0515 


0072 

0068 


0516 


0073 



0517 


0074 



0518 





0519 





0520 i 





0521 | 

1 

1 



input or output terminals. The identifications of these 
terminals and the components with which they are 
associated are shown in Table II. 

Input Terminals 

When a sense instruction refers to an input ter¬ 
minal by means of the address x, the action is as 
follows: if an electrical impulse is present on that 
terminal, the machine skips to the second instruction . 
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following the sense instruction; if no impulse is 
present, the machine continues its instructions in 
normal sequence. 

There are six input terminals on the operator’s 
p ane l; these are known as the sense-input switches 
and are identified by the addresses 0069 through 
0074. If the switch is pressed down, it is said to be in 
the on position. Thus, when the sense instruction 
refers to that switch, there will be an impulse avail¬ 
able, and one instruction will be skipped in the pro¬ 
gramming as described above. If the switch' is not 
on, no impulse is available. 

There are no input terminals on the card punch 
and only one on the printer. Use of the printer-input 
terminal is described later under Control Panel 
Wiring. 

Output Terminals 

When a sense instruction with an output terminal 


address is executed, an electrical impulse is made 
available on that terminal. No skipping of instruc¬ 
tions takes place. 

On the operator's panel are four output terminals 
that take the form of neon lights. These lights can be 
turned on individually by the program and are usually 
used to show the operator the progress of the prob¬ 
lem. The addresses of these lights are 0065 through 
0068. The output terminal whose address is 0064 
simply turns out all the neon lights. 

There are ten output hubs on the printer control 
panel, with addresses shown in Table II. By means 
of pulses made available by the sense instructions, it 
is possible to transfer selectors and effect mechanical 
control of the printer, such as double spacing, etc. 
The two output terminals of the card punch are used 
in a similar way. These output terminals actually 
take the form of hubs on the control panels of the 
components. Their use is explained under' Control 
Panel Wiring. 
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INPUT-OUTPUT 

COMPONENTS 


The card reader, card punch, printer, magnetic 
tapes, and magnetic drums will all be loosely classified 
as input-output components of the machine, because 
they all share the common property of being able to 
receive information from, or transmit information to, 
electrostatic storage automatically. In fact, it must be 
remembered that, whenever information is trans¬ 
mitted from one component of the machine to an¬ 
other, it must pass through the electrostatic memory. 

Any machine component capable of transmitting 
information both to and from electrostatic storage 
automatically (such as tapes and drums) may be re¬ 
garded as an auxiliary storage (as distinguished from 
the electrostatic “working” storage). However, the 
common input-output terminology will be used in 
this section. 

The input-output system of this machine is out- 
handing both in versatility and speed. The computer 
has full automatic control over all input-output com¬ 
ponents. Even mechanical functions of components, 
s uch as the printer and punch, may be put under con- 
trol of the program. Supplementing this mechanical 
control are the control panels for the printer, punch, 


and reader. This mechanical control is described 
under Control Panel Wiring. 

The great versatility of the system is obtained by 
the automatic control of the components via the 
stored program. For example, a binary-to-decimal 
conversion can be programmed without slowing down 
the rate of printing. These programs are accomplished 
at the expense of some storage space, but the result¬ 
ing usefulness of the machine makes it extremely 
profitable. Moreover, such programs as mentioned 
above need be written only once, and used over and 
over again. A few such basic sub-programs are given 
in Part II. 

All of the input-output components will be dis¬ 
cussed in this section to show how they operate under 
control of the stored program. Although timing con¬ 
siderations will be mentioned, exact data will be given 
in the Timing section. Also, wiring and manual con¬ 
trol of components are discussed under Control Panel 
Wiring and Manual Control of Components. 

In all instances it will be assumed that the compo¬ 
nents have been manually prepared for control by the 
calculator, such as the insertion of tapes or cards, etc. 
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PUNCHED CARDS 

In titts machine cards are intended to he the pri¬ 
mary input medium because of their great flexibility 
and because of the availability of apparatus for key¬ 
punching, verifying, and duplicating. Errors are 
easily detected and corrected, input data may be read¬ 
ily prepared on several key-punches simultaneously, 
and the cards may be collected before entry into the 
computer. Cards are particularly desirable when one 
wants to have manual access to a .file since they can 
be easily separated, and their contents may be printed 
on them. It should be emphasized that the punched 
card input and output may represent any alphabetic 
character or special symbol, provided only that a pro¬ 
gram exists to recognize the IBM code for this infor¬ 
mation. A program may also provide for quantities 
to be represented in any number system and read or 
punched accordingly. 

Entering a program on cards may be done in such 
a way that instructions are punched, one to a card, in 
the form most desirable to the programmer (e.g.. in 
decimal notation). The computer can then be supplied 
with a standard program to assemble the instructions 
in the desired order. Then, if errors are detected or if 
changes must be made, the wrong cards are removed, 
the correct ones (not necessarily the same number of 
cards) are added, and the computer prepares the new 


program. Note that there is no need to repunch an 
but the cards in question. 

The card-feeding mechanism in the card reader; 
similar to that in the Type 402 Accounting Machin 
and includes two sets of 80 reading brushes. Corrt 
spondingly, there are 80 punching magnets and 8 
punching brushes in the card punch. Only 72 column 
of the standard IBM card, however, can be read int 
electrostatic storage, and only 72 columns can h 
punched from electrostatic storage (unless split-col 
umn wiring is used). Any 72 columns of the card ca: 
be selected through control panel wiring. For sin 
plicity in the following discussion, it will be assume 
that columns 1 to 72 of the card are used for boti 
reading and punching. 

Binary information is represented on a card a 
follows: each of the 12 rows of the card is split infe 
two parts, the left half consisting of columns 1 to 3i 
and the right half of columns 37 to 72; each half rov 
can be treated as a 36-bit word and read into a full 
word location in electrostatic storage. 

o 

Figure 7 shows how the card is divided. In tlii 
particular example, the first 72 columns of the can 
are used. Each of the rows is split into half-rows o 
36 columns each. Thus, the half-row identified by tin 
circled 9 in Figure 7 is named the 5-row left. Simi 
larly. the row identified by the circled 10 is named thf 
5-row right. Thus, there are 24 half-rows in the card 
One full word of binary information can he punchec 
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in any half-row (including sign). The machine re¬ 
gards any punched hole as a binary 1. “No punch’’ 
indicates a binary 0. Thus, an 8-punch in column 36 
of the card is regarded by the machine as a binary 1 
in the least significant position of the full binary word 
punched in the 8-row left. The leftmost position of 
each half-row is reserved for the sign bit of the full 
word. A binary 1 represents a negative sign, while a 
binary 0 represents a positive sign. 

(Note : The exact position of a full word that each 
column represents is completely arbitrary according 
to how the particular control panel is wired. This 
example is the normal and simple case. The wiring- 
discussed under Control Panel Wiring assumes that 
information is to be read into the calculator as de¬ 
scribed above.) 

It should also be pointed out that this card repre¬ 
sentation of 24 binary words does not mean that the 
cards must always be punched with true binary infor¬ 
mation. The holes in the card can just as well be 
numerical punching in the standard decimal card 
I code, alphabetic punching, or control punching. It is 
necessary only to provide a suitable program so that 
the computer can translate between the binary code in 
which it operates and the particular code used on the 
card. The translation to and from the decimal nu¬ 
merical code, for instance, can proceed simultaneously 
with reading and punching so that the over-all card¬ 
handling speed is not reduced below the standard 
rates of laO cards per minute for reading and 100 
cards per minute for punching. 

Cards are fed face down, 9’s edge first, in both the 
card reader and card punch. The internal card circuits 
are arranged so that the 24 half-rows of the card are 
read or punched in the sequence indicated by the 
circled numbers in Figure 7. The sequence of read- 
ing or punching full words is then as follows: 9-row 
left, 9-row right, 8-row left, 8-row right, and so on to 
12-row left, 12-row right. 

Cor reading and punching cards, a unit record is 
defined as the information contained in one card. 
A file will consist of any number of unit records and 
S0 take the form of a deck of cards. Note that 
definitions of unit records and files will, in general, 

6 c *'C er ent, depending on the particular input or out¬ 
put component being discussed. This has been done 
0 that descriptions of input-output operations of the 
Previous section could be made to apply, as nearly as 
Possible, to all components. 


Card Reader 

For a program to cause the calculator to read all 
of the information punched on a card into electrostatic 
storage, it is necessary to give a read instruction 
with an address of 2048 (card-reader identification) 
followed by 24 copy instructions. 

The read instruction causes the card-feeding 
mechanism to start in motion. The program then is 
free to continue any operations until the 9-row of the 
card appears under the reading brushes. At this time, 
the program must provide a copy instruction with 
an address, .r. This instruction will cause the word 
punched in the 9-row left, to be read and stored in 
electrostatic location .r. The program can then resume 
until the calculator is prepared to read information 
punched in the 9-row right. The program now must 
supply another copy instruction to read this word 
into electrostatic memory. This procedure continues 
until all 24 half-rows have been read. Because of their 
functions, these copy instructions are called 9 left 
copy, 9 right copy. etc. Another read instruction 
must be given to read another unit record (card). 

Of course, the read instruction can be given, fol¬ 
lowed immediately by the 24 copy instructions in 
succession, without any other operations being done 
between instructions. In such a case the calculator 
will automatically wait until a half-row is in position 
to be read before the copy instruction is executed. 

The intervals of time between these instructions 
which may be used for useful calculating, are defi¬ 
nitely limited and are completely specified in the 
Timing section. If a copy is given after the card 
reader is in position to read a given half-row. the 
machine will stop, and the copy check light will turn 
on at the operator’s panel. The amount of calculating 
time available between the last copy instruction for a 
given card and the read instruction that initiates the 
reading of a succeeding card is unlimited. But if a 
read instruction does not occur within a definite time 
limit, the card reader will stop and will start up onlv 
atter the new read instruction has been received. To 
keep the card reader in continuous motion and oper¬ 
ating at its full speed of 150 cards per minute, the 
time limit discussed under Timing must be observed. 

Programming experience shows that it is extremely 
convenient to have this time between input-output 
instructions in order to compute succeeding copy 
addresses and to control the calculator. Calculator 
operation is such that during execution of a copy in- 
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struction, the word read from a half-row of the card 
first enters the mq register before being sent to the 
electrostatic memory. This, of course, destroys any 
information previously stored in this register. 

If a 25th copy instruction is given after a read 
instruction, the card reader will already have set up 
what is known as an “end-of-record” condition (this 
denotes that all 24 half-rows of the card have been 
read). Under this condition, the 25th copy is not 
executed, and the program skips to the third instruc¬ 
tion after the copy. In this way the program may 
transfer control to a section that will cause the suc¬ 
ceeding card to be read. 

When the card reader hopper becomes empty, the 
calculator stops on the read instruction. Two cards 
ahead of the reading station remain to be read. The 
start button may then be depressed to allow the cards 
remaining to be read under program control. After 
the last card has been read in this way and if another 
read instruction followed by a copy is given, the card 
reader sets up an “end-of-file” condition. Under this 
condition, the copy instruction is not executed, and 
the program skips to the second instruction following 
the copy. For example, control may be transferred 
to a particular section of the program that continues 
a calculation interrupted by the card-reading pro¬ 
cedure. 

The contents of the 24 locations of the electrostatic 
memory, into which the 24 half-words have been 
read, is known as the card image. By a program that 
suitably manipulates this card image, decimal infor¬ 
mation punched in standard IBM code may be con¬ 
verted to binary information. 

In reading cards it is not always necessary to follow 
a read by 24 copy instructions. The card reader will 
normally read half-rows for every following copy 
instruction up to 24. If, however, after a few copy 
instructions, another read is given, the card reader 
automatically ignores any succeeding half-rows that 
have not been read and starts reading a new card. 
Thus, for instance, it is possible to read the first five 
words of a card and ignore the rest. It is not possible, 
however, to read the first five words, skip the sixth 
and seventh words, and continue on reading the card. 
A copy instruction designed to accomplish any read¬ 
ing of this type will always result in a machine stop 
and a copy-check light. If successive read instruc¬ 
tions are given with no intervening copy instructions, 
the net result is the feeding of cards through the ma¬ 
chine with no words being read into storage. 


Card Punch 

The operation of punching information on a can 
is very similar to that of card reading. To make us| 
of these similarities, it will be assumed that the pro 
gramming necessary for card reading is understood 

Punching a card requires a write instruction hay. 
ing an address of 1024 (card-punch identification! 
which sets the card-feeding mechanism of the puncl 
in motion. 

Following write, a succession of copy instruction; 
is given, the address parts of which give the location; 
in electrostatic storage where the words to be punchec 
in the half rows of the card are to be taken. To puncl 
a full card, 24 copy instructions must be given. Thest 
copy instructions are called, as in card reading, 1 
left copy, 9 right copy, etc. A separate write instruc¬ 
tion must be given for each card to be punched. Corre¬ 
sponding to card reading, a certain amount of com¬ 
puting can be carried out between write and the firs; 
copy instruction and between successive copy in¬ 
structions. 

For example, binary to decimal conversion can k 
completed while a card is being punched. Each com 
instruction, however, must have been given by the 
time the corresponding half-row appears at thf 
punching station. These time limits are specified 
under Timing. If time limits are exceeded, the ma¬ 
chine stops, and the copy check light on the operator’s 
panel signals the error. To keep the punch running at 
its full speed of 100 cards per minute (and if mors 
than one card is to be punched) succeeding write 
instructions must be given within a certain time in¬ 
terval. Otherwise, if a write instruction is delayed 
too long, the punch will stop and will not start again 
until the write is actually given. It these write and 
copy instructions are given in succession, the com¬ 
puter delays until a half-row is actually in position to 
be punched. 

If fewer than 24 copy instructions are given, the 
remaining half-rows on the card, for which there 
were no-coPY instructions, are left blank. 

Again, we must remember that the mq register 
serves as an intermediate storage during a copy in- 
struction. Since the word to be punched first enters 
this register before being sent to the card punch, an) 
previous information in the register is destroyed. 

There are no end-of-record or end-of-file condition- 1 
in punching cards. 
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PRINTER 

The printer, which is a modification of the printing 
unit on the IBM Type 407 Accounting Machine, is 
equipped with 120 rotary type-wheels. Each wheel 
has 48 characters, including Arabic numerals, alpha¬ 
betic symbols, and special characters. By means of a 
proper program the machine can be made to print 
decimal numbers, binary numbers, or numbers to any 
other base. Titles and headings are also possible, since 
alphabetic characters and special symbols are pro¬ 
vided on the type-wheels. 

As in the standard Type 407, the type-wheels are 
positioned for printing by electrical pulses timed ac¬ 
cording to the print cycle itself. Thus, it will be re¬ 
called that if a print-wheel receives an electrical 
impulse during that part of the print cycle designated 
as 9-time, then the print-wheel will be positioned to 
print a 9. Also, if the print-wheel receives an impulse 
at 1-time and an impulse at 12-time, the machine will 
interpret this as the letter A (according to the stand¬ 
ard IBM code) and will position the type-wheel to 
print this character. It is important to understand 
this timing principle of accounting machines. Refer¬ 
ence may be made to the Type 407 Accounting Ma¬ 
chine principles of operation manual. 

A simple example is used to show how a series of 
nines might be printed in 72 positions of a line. 

Example : A write instruction with an address of 
0512 (printer identification) is programmed. This 
causes the printer to start a print cycle. As the print 
cycle progresses, it goes through points in the cycle 
known as 9-time, S-time, 7-time, and so on to 
11-time and 12-time. These times are analogous to 
the times designated for the standard Type 407, 
which operates in conjunction with a card-reading 
mechanism. Thus, in the standard Type 407, the 
above times are in exact coincidence with the time 
the 9-row is under the reading brushes, etc. As 
soon as the 701 printer reaches 9-time in its cycle, 
the program must furnish a copy instruction that 
reads a full word from an electrostatic storage 
location. By means of control panel wiring (see 
Control Panel Wiring) this full word is directed to 
6 type-wheels (one for each bit of information) 
of the printer. A second copy instruction then fol¬ 
lows, this causes another full word in electrostatic 
storage to be directed to 36 other type-wheels. 
These two copy instructions are given close enough 


together (with respect to time) that the printer is 
still essentially at 9-time of its cycle. A binary digit 
of 1 in the full word will cause an electrical pulse 
to enter the printer and to impulse the associated 
type-wheel. This impulse will cause the type-wheel 
to be positioned for printing a 9, since the impulse 
arrived at 9-time of the print cycle. If now we as¬ 
sume that both full words mentioned in connection 
with the above two copy instructions consist of a 
negative sign and 35 binary ones, the result will 
be 72 nines printing across the page. This assumes 
that any subsequent copy instructions correspond¬ 
ing to 8-time, 7-time, etc., will not cause an addi¬ 
tional impulse to a type-wheel and thus cause the 
wheel to be positioned in a different manner. A 
positive sign or a binary zero will not propagate a 
pulse to the type-wheels. 

The general procedure in printing a line is to set 
up in electrostatic storage a card image similar in 
nature to the card image produced when a card is 
read by the card reader. A write instruction then is 
followed by 12 pairs of copy instructions; these cause 
the card image to send impulses to the type-wheels. 
The first pair of copy instructions will cause 9-time 
impulses to be sent to the type-wheels as explained in 
the example above. The second pair will cause 8-time 
impulses to be sent to the type-wheels. This procedure 
continues until the 12 pairs of instructions are exe¬ 
cuted in accordance with the 12 distinct times of the 
print cycle. Subsequent write and copy instructions 
will result in a new print cycle and a new printed line. 
The full-word impulses, brought about by execution 
of the first copy instruction of a pair, are available at 
the hubs labeled calc exit leet on the printer con¬ 
trol panel and may be directed to the selected tvpe 
wheels by wiring. The impulses produced by the 
second copy instruction of a pair are available at the 
hubs labeled calc exit right. For various reasons 
described above, the 24 copy instructions will be 
named in sequence, as follows: 9-left copy, 9-right 
copy, 8-left copy, 8-right copy, and so on to the 12- 
left copy, 12-right copy. 

As in the card reader and card punch, it is possible 
to do useful calculating between the actual printing 
instructions. For example, the time required for the 
print cycle to start, and move to 9-time of its cycle, 
may be used for other calculations. Once the cycle has 
reached 9-time, however, the program must provide, 
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in succession, the pair of copy instructions for im¬ 
pulsing the type-wheels. Useful calculating can also 
be performed between pairs of instructions and even 
between individual instructions of a pair. As before, 
there are definite time limits to be observed. These are 
precisely specified under Timing. If a copy instruc¬ 
tion arrives too late in the cycle, the machine will 
stop, and the copy check light will indicate the error. 
For the machine to print at its full rate of 150 lines 
per minute, the write instructions for each print 
cycle must be given in the interval of time explained 
under Timing. If write instructions do not follow 
each other within this time limit, the printer will stop 
and will start again only on receipt of the next write 
instruction. If we do not want to do calculating be¬ 
tween these input-output instructions, we can pro¬ 
gram these instructions in immediate sequence. 
Under these conditions, the calculator will automati¬ 
cally wait until the printer reaches the proper point 
of its cycle before executing the instructions. Also, it 
is not always necessary to give a full set of 24 copy 
instructions for each line of print. If a full set is not 
given, the action will be similar to the card reader; 
namely, the print cycle will continue without any 
more impulses to the type-wheels, and a following 
write instruction will start a new cycle. 

Again, the mq register is used as an intermediate 
storage for a full word passing from electrostatic 
memory to the printer; so the execution of any copy 
instruction destroys information previously standing 
in the register. 

The previous paragraphs give the procedure for 
printing without checking. Checking is possible be¬ 
cause the printer is capable not only of receiving print 
pulses from the calculator to set up the type-wheels 
for printing, but also capable of sending to the calcu¬ 
lator "echo pulses" generated by the type-wheels 
according to what character the wheels are in position 
to print. Printing with checking, however, requires a 
somewhat more complicated program, but it can be 
done without reducing printing speed. The timing for 
this combination is roughly as follows: 

The first half of the print cycle is used to position 
the type-wheels by means of words in electrostatic 
storage. The second half is used for reading the "echo 
pulses” generated by the type-wheels and for placing 
them in electrostatic storage for verification via a 
programmed check. 

When it is desired to check, the echo pulses are 
read in such a way as to form a card image when re¬ 


ceived by the calculator. Thus, the calculator can botli 
write the original card image for printing and read a 
corresponding card image, at a later time in the same 
print cycle, from the echo pulses. If the two card 
images do not agree exactly, as determined by a suit- 
able program, then an error must have occurred. Only 
numerical information can be checked this way. 

Printing with checking is programmed as follows. 
First a read instruction (note this difference), with 
the address of the printer, is given, followed by 46 
copy instructions in a specified sequence. Twenty, 
four of these copy instructions refer to printing, and 
cause words to be sent from electrostatic storage to 
the printer. The other 22 copy instructions refer to 
checking. They require words to be read from the 
printer into electrostatic storage. During part of the 
print cycle, the two kinds of copy instructions must 
alternate in pairs. Note, then, that the read instruc¬ 
tions will cause both writing information from stor¬ 
age to printer, and reading the echo impulses into 
storage. 

Exact sequence of the 46 copy instructions for 
printing with checking is described below. There are 
two sets of codes for plus and minus signs, as follows: 
with one set, used for printing without checking, 12 
is the code for plus, and 11 for minus; with the other 
set, used for printing with checking, the combination 
of 8 and 3 is the code for plus, and 8 and 4 the code 
for minus. 

The first 18 copy instructions are to supply im¬ 
pulses to the printer from the left and right halves of 
rows 9 through 1 of the card image. The 19th and 
20 th copy instructions are for storing the echo im¬ 
pulses received from the minus sign (code 8, 4). The 
21 st and 22nd copy instructions send impulses to the 
printer from the zero row of the card. The 23rd and 
24th copy instructions store echo impulses received 
from the plus sign (code 8. 3). The 25th and 26th 
send the 11-row of the card image to the printer. The 
27th and 28th are for checking the 9-row. The 29th 
and 30th send the 12-row of the card image to the 
printer. Finally, the 31st through 46th copy instruc¬ 
tions form the check images of the 8-row through the 
1-row. The fact that no checking is provided for the 
0 . 11, and 12 rows explains the two separate codes for 
plus-and-minus signs. The exact sequence of instruc¬ 
tions and the allowable time between them are full)' 
explained under Timing. 

Through use of selectors or column splits on the 
printer control panel, more than 72 type-wheels can 
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be activated from electrostatic storage. For example, 
seven 10-digit numbers with signs can be printed. 
Additional characters can also be printed by means of 
impulses emitted on the control panel. Alternatively, 
the control panel can be wired so that up to 120 char¬ 
acters originating from electrostatic storage can be 
printed on each line at the rate of 75 lines per minute, 
two cycles being required for each line of printing. 

The printer has an IBM tape-controlled carriage, 
details of which are found in the manual of operation 
for the IBM Type 407 Accounting Machine'. Func¬ 
tions of the carriage (such as changing or suppress¬ 
ing line spacing, selecting the channel on the punched 
tape to control skipping, or sensing sheet overflow) 
may be controlled through sense output or input hubs 
on the control panel; these hubs are activated by ap¬ 
propriate sense instructions in the stored program. 


MAGNETIC TAPES 


Magnetic tapes may be used either as a high- 
capacity long-term memory or as input from a pre¬ 
vious problem that had stored its results on tape. 
Input data from cards, including programs, can be 
transcribed by the computer on tape to conserve stor¬ 
age space or to save time when the data must be 
repeatedly entered into the computer. Libraries of 
standard sub-programs, which can be called on to re¬ 
duce the amount of programming required for each 
problem, can also be stored on tape. 

There are four tape units; each contains a magnetic 
tape of any length up to 1400 feet. The tape itself is 
one-half inch wide, oxide-coated, and non-metallic. 
After the tape has been placed in motion, it can read 
or write information at the rate of 1250 words per 
second. 


Information is recorded on tape in six channels 
that run parallel to the length of the tape. A bit of 
information is represented by a magnetized spot in a 
channel. A set of six bits recorded in a line perpen¬ 
dicular to the six channels will be referred to as a 
group of bits. Six groups recorded serially on a tape 
are needed to store one binary word of 36 bits. 


A seventh channel on the tape serves to check the 
reading and writing in the other six channels by the 
s °-called “redundancy check’’ principle. That is, either 
a 0 or 1 is recorded in the seventh channel so that 
across the seven channels there is an odd number of 
1 s in each set of seven bits. When the tape is read, 


the number of l’s is automatically checked. If the 
number is even, the calculator stops, and the tape- 
check light on the operator’s panel is turned on. If the 
number of l’s is odd (as it should be when correct), 
the machine continues the reading and writing proc¬ 
ess. It should be emphasized that operation of this 
seventh channel is completely automatic and is 
brought out to indicate the function of the tape-check 
light on the operator’s panel. 

A schematic diagram of how a word of 36 bits is 
recorded on tape is shown in Figure 8. Each X de¬ 
notes a binary 1 or 0 recorded in that position on the 
tape. The 36 bits recorded in the six recording chan¬ 
nels represent the full word. When the tape moves in 
the direction of the arrow, the group numbered 1 
will contain the sign and first five bits of the word. 
The remaining five groups contain the following bits 
of the word in groups of six. Thus, group 2 contains 
bits 6 through 11 of the word, etc. 
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Figure 8 


Writing 

The general procedure for writing a file of infor¬ 
mation on a tape is as follows: A write instruction 
is given with an address designating a particular one 
of the four tapes (see Address System). This in¬ 
struction causes the selected tape to be started in 
motion and prepares it to record a unit record of 
information from electrostatic storage. 

The writing process requires that all previous mag¬ 
netic marks be erased from that portion of the tape 
being written upon. To accomplish this, an erasing 
apparatus precedes the recording apparatus by ap¬ 
proximately two inches. Thus, as the tape moves 
under the impetus of the write instruction, the eras¬ 
ing apparatus is continually active, while the record¬ 
ing apparatus does not operate until told to do so by 
the program. 
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If the write instruction is given when the tape 
unit is in the rewound position (i.e., in position to 
write a file of records), the actual writing on tape is 
delayed eight-tenths of a second. The erase circuits, 
however, are functioning during this time, and there 
results a blank portion of tape called the beginning-of- 
file gap. 

As soon as the beginning-of-file gap has been 
written the program must supply a copy instruction. 
This instruction takes the full word stored in the 
electrostatic storage location specified by the address 
part of the copy instruction, and puts it into the mq 
register. The selected tape unit then takes this word 
from the mq register in groups of six bits each, and 
records them on the tape in the manner shown in 
Figure 8. By the time all six groups of bits have been 
recorded, the program must furnish another copy 
instruction for recording the second word of the rec¬ 
ord. The copy instructions may continue in this way 
until the entire unit record is written. This is called 
a copy loop. In computing the time consumed by a 
copy loop, the copy instruction itself is not included. 
If X microseconds are available between successive 
copies, they exclude the copy instruction. If an in¬ 
struction is furnished by the program before the tape 
unit is ready for it, the execution of the instruction 
is automatically delayed. 

Note that the length of the unit record is variable 
and depends only on the number of copy instructions 
following the write instruction. If the tape unit is 
ready for a copy instruction (which means it has 
finished recording the last word), but the program 
fails to supply this instruction, the tape unit auto¬ 
matically disconnects itself from the calculator and 
stops. Because of the time necessary for the tape to 
come to a complete stop and the two-inch distance 
between the erase head and writing head, there results 
a small section of erased tape. The gap caused by this 
erasure will be called an end-of-record gap; these gaps 
are extremely convenient when reading words back 
into electrostatic memory. When the programmer 


wants to end a unit record, he simply stops supplying 
the calculator with copy instructions. If a copy in. 
struction is given after the tape unit disconnects, thf 
entire computer stops, and the copy-check light sig. 
nals the error. _ 

The first unit record of the file has now been 
written. To write a second unit record, the same pro. 
cedure (write instructions followed by copy instruc¬ 
tions) is programmed. In this way a series of records 
is recorded. Note again that the records may be o| 
variable size if desired. A series of write instructions 
with no copy instructions will result in the tape mov¬ 
ing through the machine and being erased. If a new 
write instruction is given while the machine is still 
recording the last word of the previous record, the 
program is automatically delayed until the tape, has 
erased an end-of-record gap, and is prepared to accept 
the first word of the new record. 

The complete recording on a tape consists of a 
number of unit records that make up a file of informa¬ 
tion. Tapes can be re-used many times, and a new file 
can be written over an old file, the old one being 
erased in the process. Each time a new file is written, 
it is started at the beginning of the tape, and only one 
usable file of unit records can be on a tape at one time. 
Different files, however, will have different lengths, 
so that there is a possibility that beyond the last 
record of the most recent file, there may be bits left 
over from a previous use of the tape. These residual 
bits of information may not be properly spaced with 
respect to the record just written. This may result in 
an error on a later reading of the new record. To 
avoid having to erase the entire tape every time, and 
for certain control purposes to be mentioned later, an 
instruction called Write End of File (abbreviated to 
write ef) has been provided. This instruction, which 
must be given after writing any file, erases a further 
section of tape after the last unit record. The section 
of tape erased in this way is called an end-of-file gap- 

Figure 9 shows schematically how a typical file of 
information is recorded on tape. The arrow desig- 
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nates the forward direction of tape motion. Writing 
can be done only when the tape is moving forward. 
A beginning-of-file gap is followed by a number of 
unit records with the intervening end-of-record gaps. 
Note that these gaps are of a fixed length regardless 
of the length of the unit record itself. Finally, an end- 
of-file gap appears after the last unit record. Note, 
too, that the machine operates so that lengths of the 
two gaps at each end of a file are equal to each other, 
but longer than end-of-record gaps. All of these items 
will play an important role when a program is re¬ 
quired to read this information back into storage. 

To recapitulate, there are three kinds of gaps in the 
recording of information on tape: 

1. The normal spacing between successive groups 
of six bits within a unit record. 

2. The longer gap between unit records. This gap 
is long enough to allow the tape to stop and 
start between records if desired. 

3. The still longer gaps at the ends of the file. 

As in other input-output devices, it is possible to 
do useful calculating (such as the computation of the 
addresses of succeeding copy instructions) between 
the write instruction and first copy instruction and 
between successive copy instructions. Again, this 
time is limited and is specifically discussed under 
Timing. It will be recalled, however, that the mq 
register is in continuous use after each copy instruc¬ 
tion, because the word is recorded six bits at a time 
on tape. This observation means that between copy 
instructions no calculating can be done that requires 
use of the mq register. This restriction specifically 
excludes the following operations: store mq, load 
mq, mpy, mpy r, div, round, l left, and l right. 
(In devices previously discussed, the mq register is 
used only during execution of the copy instruction 
and simply destroys the number previously stored 
there. The mq register could be used between copy 
'nstructions in those instances.) 

After the last copy instruction for writing a unit 
record has been given, the mq register is in use as 
before. Consequently, the programmer must be sure 
that a certain amount of time elapses (while the last 
word is going from the mq register to tape) before 
Programming any instructions involving the mq reg- 
■ster. There is an instruction available to the pro¬ 
grammer for delaying the program until the mq 
re gister is free for use. By using this delay instruction 
after each unit record, the programmer need not 


worry about'the delay. The delay instruction is 
“write 2052.” Note that this instruction, if inter¬ 
preted in the usual way, is nonsense, since 2052 does 
not identify any component of the machine. However, 
the machine circuits are so set up that it will recog¬ 
nize this particular instruction as a delay instruction, 
and the program is automatically held up until the 
M Q register is not being used. 

Note that the mq register is not in use with the tape 
unit between the write instruction and the first copy 
instruction for a unit record. Consequently, there are 
no restrictions on use of the mq register by the pro¬ 
gram when using the calculating time available 
between these instructions. Note, also, that the mq 
register is not required by the write ef instruction, 
and the program can continue unrestricted in this 
case. 

Reading 

Reading information stored on tape is similar in 
many respects to the writing process. Because of this 
similarity, the description of reading a file of records 
will be more abbreviated than the preceding para¬ 
graphs. 

Assume that the tape is in position to read the first 
unit record of a file. A read instruction, with an 
address to select the particular tape to be read, causes 
the tape to start in motion. This instruction also 
causes the mq register to reset to zero (a read in¬ 
struction causes this only when the address designates 
a tape unit). Subsequent copy instructions will cause 
a word to be loaded six bits at a time into the mq 
register, and from there the whole word is sent to the 
electrostatic location specified by the address part of 
the copy instruction. Words thus read into storage 
are available to the programmer immediately. When 
the tape unit comes to the first word of the unit record, 
it places it. six bits at a time, into the mq register. 
\\ hen the word is completely assembled, the program 
must supply a copy to transfer the word to memory. 
The copy can then follow and the tape continues to 
move as the record is read. 

But eventually the tape comes to the end-of-record 
gap. The machine recognizes this gap, the tape stops, 
and an end-of-record condition is set up. If, under 
this condition, the program supplies another copy 
instruction, the machine will not execute it, but will 
skip to the third instruction following the copy in¬ 
struction. This allows the program to" follow a dif¬ 
ferent course after finding the end of a record on read- 
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ing. It is not necessary to know the number of words 
stored in a unit record, because the tape will auto¬ 
matically stop after reading the entire record. 

However, it is not necessary to read and store 
every word of a record. After reading the number of 
words desired, the program may go on to something 
else, and there will not be another copy instruction 
waiting the next time the mq register is filled with a 
word from the tape. This causes the tape unit to dis¬ 
connect itself from the mq register. The mq register 
can then be used by the program for other purposes; 
but the tape itself does not stop until it comes to the 
end-of-rccord gap. As explained in the previous sec¬ 
tion for writing on tape, the delay instruction 
(write 2052 ) should follow the last copy instruc¬ 
tion to delay the program and avoid an overlap be¬ 
tween the next word of the record (which will enter 
the mq register before the tape unit discovers the 
absence of a corresponding copy instruction) and 
any instruction that may require the mq register. But 
the delay instruction is not necessary when the entire 
unit record is read. 

In general, the programmer has four alternatives 
for disposing of the words of a unit record after 


riving a read instruction : 


He may give a series of copy instructions to 
store every word of a unit record; and he may 
continue to do so until the end of the record is 
signaled by the end-ot-record gap. Often this is 
the simplest way of reading the entire record, 
and it is particularly useful when the exact 
number of words in the record is not available 
and need not be known. The delav instruction 


is not necessarv. 


He may know the number of words in the unit 
record and give only as many copy instructions 
as there are words in the record. He would 
then continue without waiting for an end-of- 
record signal. In this case the delay instruction 


need not be given. 


3. He may read and store fewer words than there 
are in the unit record. When a sufficient num¬ 
ber of copy’s have been given, he may give 
write 2052 to delay the program and force the 
tape unit to disconnect. Then he may continue 
with a different program and ignore the rest of 
the unit record. 

4. He need not give any copy instructions. In 
that case the tape unit will put the first word 


into the mq register. When it does not find a 
copy instruction waiting at the end of this 
word, the tape unit will disconnect immediately, 
The tape itself, however, continues to move 
through the entire unit record until it reaches, 
the end-of-record gap. Nothing will have been 
stored in memory. This device makes it pos¬ 
sible to skip through one or more unit records 
to the desired one without storing the unwanted 
records in memory. (If there is any danger of 
overlap in the use of the mq register, then the 
delay instruction should be used here, too.) 

In any case, the tape unit continues to run after a 
read instruction until it comes to the end of the unit 
record, regardless of how much of the record is actu¬ 
ally being read. If two read instructions follow each 
other too closely, the second is held up until the tape 
unit has reached the end of the previous unit record 
and is ready to read another, because every read in¬ 
struction applies to a new unit record. 

All of the unit records in a file can be read as 
described above. After the last unit record in the file 
is read, however, the tape is positioned at the begin¬ 
ning of the end-of-file gap. If, at this time, another 
read instruction is given, the tape unit starts up and 
attempts to read another unit record. Instead of a unit 
record, it finds the end-of-file gap, and after sufficient 
searching for a new unit record, the tape unit again 
stops and sets up an end-of-file condition within the 
machine. If, under this condition, the program sup¬ 
plies a copy instruction (as if it were going to read 
the first word of the new unit record), the copy in¬ 
struction will not be executed, and the program will 
skip to the second instruction following the copy. The 
programmer may then take advantage of this auto¬ 
matic skip to go into a new program. This end-of-file 
condition cannot be obtained from a blank tape; at 
least one unit record must be written on the tape to 
distinguish the normal space at the start of the file 
from the end-of-file gap obtained by use of the 
write ef instruction. 


The end-of-file, of course, can be taken into account 
by giving the same number of read instructions as 
there are unit records. But the automatic end-of-file 
feature is very convenient when the number of unit 
records is not known directly or when it is of no 
interest, such as when reading through a library of 
programs on tape. Although the end-of-file gap may 
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n ot be used, it is always necessary to give a write ef 
instruction after zvriting a file (see above section). 

As in writing, useful calculation can be clone be¬ 
tween the input-output instructions. Again, the time 
is definitely limited and is discussed below under 
Timing. If a copy instruction is given after the speci¬ 
fied time interval has elapsed, the machine stops and 
the copy-check light turns on to signal the error. The 
restrictions on use of the mq register between copy 
instructions is the same as for writing. As with .writ¬ 
ing, calculating may be done between a read instruc¬ 
tion and the first copy instruction of a unit record, 
but there is one important difference. The mq register 
is reset to zero by the read instruction. This is done 
in preparation for the following copy instruction 
which assumes that the mq register is actually zero. 
Thus, the mq register should not he used for calculat¬ 
ing during this interval. 

Note : The programmer may use the mq register 
during this interval if he takes extreme care to reset 
this register to a positive zero (via the program) 
before the tape unit starts to put the first word into 
the mq register. This is not good practice, however, 
and should be done only if absolutely necessary. Note 
in particular that the program must reset the mq 
register to zero before the tape unit comes to the first 
word and net simply before the first copy instruction. 
This requires a thorough understanding of tape 
timing. 

A tape can be read backward one unit record at a 
time by giving the instruction called Prepare to Read 
Backzvard (abbreviated to read b) in place of read. 
This instruction differs from read only in that it 
causes the tape to move in the reverse direction. 

There are two uses of read b. One is to backspace 
a tape by a given number of unit records. This is done 
simply bv giving the appropriate number of read b 
mstructions. Also, by means of the read b instruc- 
t'°n, the tape can actually be read in reverse order 
and part or all of a unit record stored in electrostatic 
storage. This is done by giving read b, followed by a 
suitable number of copy instructions. Under these 
drcumstances, it is evident that the words will be 
re ad in the reverse order in which they were written. 
Although the words are read in reverse order, the 
Machine automatically arranges the bits within the 
W °rd into their correct order before placing the word 
111 the mq register. 


When reading a tape backward, an end-of-record 
gap is recognized just as in reading forward. After 
the unit record at the beginning of the file has been 
read backward, the machine will be positioned at the 
beginning-of-fi!e gap. A further read b instruction 
causes the tape unit to treat the beginning-of-file gap 
as if it were an end-of-file gap. 

In general, the procedure and controls available 
when reading backward are the same as when read¬ 
ing forward. Restrictions on use of calculating time 
between instructions are identical to those imposed 
when reading forward. 

Rewinding 

The rewind instruction is used to cause the tape 
specified by the address part of the instruction to re¬ 
turn to the starting point of its file of records. 

A rewind instruction may be given in the course 
of reading a file, or after the end-of-file condition has 
been sensed, or while the tape is disconnected. If 
rewind is given while the tape is being read, the tape 
will go to the end of the unit record before rewinding. 
When writing a tape, a rewind instruction should 
not be given until after a write ef instruction has 
been used to terminate the file properly. Information 
cannot be read from nor written on the tape during ' 
rewinding. While this instruction is being executed, 
the program may continue, and may use anv other 
input-output unit; but if it calls for a tape unit still in 
the rewinding process, the program is held up until 
the tape unit has stopped. 

Tape Status 

It is not possible both to read and write on a single 
passage of the tape in one direction through the tape 
unit. If information is being written on a tape, the file 
should first be completed by writing an end-of-file gap 
before the information is read. The tape can then be 
read backward immediately, or it can be rewound and 
then read in the forward direction. When a tape has 
been used for reading, it must first be rewound com¬ 
pletely before any new information can be written 
on it. 

There are circuits associated with each tape unit 
that remember whether the tape is being read or 
written. When the circuits are set up for reading, the 
tape unit is said to be in read status; when the circuits 
are set up for writing, the tape unit is said to be in 
write status. If the tape unit is in neither read status 
nor write status, it is said to be in neutral status. 
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Lights on each tape unit indicate the status of the 
unit. The reading light is on for read status, the writ¬ 
ing light is on for write status, and both are off for 
neutral status. 

When a tape unit is in read status, it may be used 
only for reading; when in write status, it may be used 
only for writing. If a write or a write ef instruc¬ 
tion is given for a tape unit that is in read status, the 
instruction is not executed, and the tape remains 
stopped. If a copy instruction fellows the write in¬ 
struction, the calculator will stop and the copy-check 
light will turn on. Similarly, giving either read or 
read b instructions for a tape unit in write status 
results in the instruction being ignored; any subse¬ 
quent copy instruction would again be treated as an 
error. 

Any read or write instructions will be executed 
in the normal manner if the tape is in neutral status 
upon which the tape unit will be set to read or write 
status, respectively. Any of the following actions will 
always restore a tape unit to neutral status, irrespec¬ 
tive of its previous status: 

1. Giving a rewind instruction for the tape unit. 

2. Opening the door of the tape unit (to insert a 
new tape). 

3. Turning off the power. 

A write ef instruction will return a tape to neutral 
status only if it is originally in write status. 

Table III shows the resulting status of the tape 
after an instruction has been given under various con¬ 
ditions of read, neutral, and write. 

Rewind will be executed with the tape unit in any 
status. However, rewind should not be given while 
the unit is in write status, unless an error has been 
detected and the operator simply wishes to write over 
the unfinished file from the beginning. Normally, 


write ef, which resets the tape unit to neutral, must 
precede rewind. A rewind instruction must always 
be given before one can write, even after reading 
backward all the way to the beginning. Once a tape 
has been rewound, further rewind instructions may 
be given, but they will be ignored as long as the tape 
remains rewound. 

After an end-of-file gap has been written by means 
of a write ef. the tape unit will be in neutral status. 
Then it must not be attempted to give a read, write, 
or another write ef instruction which would move 
the tape further forward, although the neutral status 
would permit such meaningless actions. Only read b 
or rewind can follow write ef for the same tape 
unit. 

When a tape is being read in the forward direction 
and the end-of-file gap has once been sensed as pre¬ 
viously described above, no further read instructions 
should be given which would move the tape further 
forward. Only read b or rewind can follow the de¬ 
tection of the end-of-file gap. Similarly, after sensing 
the beginning-of-file gap and setting up an end-of-file 
condition on reading backward, or after giving a 
rewind, one must not give any more read b instruc¬ 
tions. 

Simultaneous Tape Duplication 

It is possible to write duplicate tapes simultane¬ 
ously. The following sequence is an example of the 
system for programming this operation : 

write 0001 

write 0002 

write 0403 

—COPY 

The first two instructions set up unit selectors 1 
and 2. The third instruction sets the class selector for 


Table III 


Instruction 

iResulting Tape Status If Original Status Was : 


Read 

Neutral 

Write 

READ 

Read 

Read 

Write* 

READ B 

Read 

Read 

Write* 

WRITE 

Read* 

Write 

Write 

WRITE EF 

Read* 

Neutral 

Neutral 

REWIND 

Neutral 

Neutral 

Neutral 


* Instruction treated as no operation. 
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tapes and further sets the third unit selector. Thus at 
the time the copies are executed, the three tapes will 
be written. The system works for all unit records at 
least four full words in length. An end-of-file should 
be written individually for each tape since each tape 
must be rewound separately. 

Multi-File Tape Operation 

More than one file may be placed upon a single tape 
by either of the following two methods: 

la. Program a series of write tape instructions 
following the last copy instruction of the 
previous file. 

b. The minimum number of write instructions 
necessary to distinguish the ATh file from the 
(A"+1) th file is twenty. 

c. Reading a multi-file tape is quite straight¬ 
forward with recognition of the end of the 
file as one method of advancing to the next 
file. 

d. It is necessary that the programmer maintain 
his proper position within the tape by keeping 
a count of the files on that tape. 

2. Give a write ef just before giving a write 
for the next file. This does not allow- the heads 
to be turned off. 

Method 2 is slower than method 1 but requires 
less programming. 

MAGNETIC DRUMS 

The magnetic drum storage is divided into blocks 
of 2048 full words, each with addresses consisting of 
the even integers from 0000 to 4094. Each block will 
be referred to simply as a drum. These drums provide 
an auxiliary memory that is more accessible than 
tapes or cards. Individual words on the drum can be 
selectively altered at any time. Drums are used to a 
large extent for storing tables of data and sections of 
long programs that may not fit into the electrostatic 
memory. It should be noted that words on a drum 
cannot be split into half words as in electrostatic 
storage. 

Information is usually recorded on the drum as 
blocks of full words called unit records. The w'ords of 
a unit record are stored in locations with consecutive 
brum addresses, although the first word of a record 
nia y be placed at any drum address. 

Words are transmitted between electrostatic stor¬ 


age and drum storage via the mq register just as in 
the card reader and card punch. 

Writing and reading on a drum are so similar that 
they will be discussed together. The following para¬ 
graphs show how to write a unit record on a drum. 
The reading process is identical, except that a read 
instruction is given in place of a write instruction. 

A write instruction with an address specifying a 
particular one of the four drums is given. This in¬ 
struction causes the specified drum to be connected to 
the calculator for writing purposes. This instruction 
is then followed by a Set Drum Address instruction 
(abbreviated to set dr), whose address specifies the 
location where the first word of the record is to be 
written. If the address part of a set dr instruction is 
an odd number, the address part is treated as the next 
lower integer. The sign of the instruction is immate¬ 
rial. A series of copy instructions (one for each word 
of the record) follows. The first copy instruction 
causes the calculator to be held up until the drum loca¬ 
tion specified by the address part of the preceding 
set dr instruction passes under the drum heads. The 
first word is then written from the electrostatic stor¬ 
age location specified by the first copy instruction 
into the specified location on the drum. From then 
on, consecutively even-numbered drum locations ap¬ 
pear under the drum heads at regular intervals; each 
time this happens, a copy instruction must be sup¬ 
plied if another word is to be written or read. Thus, 
the second copy instruction will cause the number 
stored in the electrostatic location given by the ad¬ 
dress part to be recorded on the drum at the address 
two higher than the first word. 

This continues by means of copy instructions, with 
each word being automatically written at consecutive- 
numbered even addresses of the drum. If the new con¬ 
secutive drum location appears under the drum heads 
and no copy instruction is supplied by the program, 
the drum disconnects itself from the computing unit. 
So when the programmer wants to end a unit record, 
he simply stops giving copy instructions. If a copy 
instruction is supplied after the drum disconnects and 
before other write and set dr instructions are given, 
the machine stops, and the copy-check light signals 
the error. 

This means that successive copy instructions must 
be given within certain time intervals (given later 
under Timing). Calculations may be performed be¬ 
tween the input-output instructions; the only restric- 
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tion on use of the mq register is to remember that its 
contents are destroyed upon execution of a copy 
instruction. 

The division of the drum storage into unit records 
is quite arbitrary. Hence, if only a single word is to 
be read or written, it is treated as a one-word unit 
record. Write or read selects the drum, set dr 
specifies the drum location, and a single copy gives 
the memory location of the word. 

There are no end-of-record or end-of-file condi¬ 
tions on the drums. These are not necessary, because 
any particular word on a drum may be located by- 
means of the set dr instruction, and the length of the 
records is variable. 

The method of reading a block of words that begins 
at any drum location is almost identical to writing a 
record. Again, the above explanation may serve for 
reading by replacing the word write by read in every 
instance. 

The following limitations must be observed in pro¬ 
grams for reading or writing on drums: 

1. There is no limitation on the length or location 
of a unit record, except that if it is attempted to read 
or write beyond drum address 4094. the next address 
will be 0000. Nothing prevents a unit record from 
being started at address 0000. 

2. Omitting the set dr instruction is equivalent to 
giving set dr with address part 0000. 

3. Any number of instructions (except input-out¬ 
put instructions) may intervene between read or 
write and set dr and between set dr and the first 
copy instruction. Successive copy instructions, how¬ 
ever, must follow each other within a definite time 
limit. If a copy arrives too late, the drum will have 
been disconnected, and the calculator will stop with 
the copy-check light turned on. 

SUMMARY 

Principal rules governing the use of the card 
reader, card punch, printer, tape units, and drums are 


summarized below. This summary repeats informa, 
tion already given in the preceding pages. 

1. Only one input-output component can be used 
at a time for reading or writing a unit record. 

2. In using any input-output component, copy 
instructions must follow one another within a definite 
time limit. If a copy instruction is not available 
within this limit, the device in use will be disconnected 
from the computing unit, and no more information in 
that unit record can pass to or from electrostatic stor¬ 
age. Note, however, that the card reader, card punch, 
or printer will continue in motion until the end of the 
card (or print) cycle and that a tape unit will con¬ 
tinue in motion until the end-of-record gap is reached. 

3. If a copy instruction is given when there is no 
read-write component connected to the computing 
unit (e.g.. if no read or write instruction has been 
given, or if a copy has been given too late), the cal¬ 
culator stops and a copy-check light turns on, indi¬ 
cating an error in the program. 

4. In using any of the read-write components ex¬ 
cept drums, the first copy instruction must be given 
within a definite time limit following the read, 
read b, or write instruction, as the case may be. 
After the unit record has been written or read, the 
next read, read b, or write instruction must follow 
the last copy instruction within a definite time limit, 
it the device in use is to be kept in uninterrupted 
motion. 

5. The following rules apply to tapes only: 

(a) During the reading or writing of infor¬ 
mation on a tape, the mq register cannot be 
used for any other purpose. 

(b) It is not possible to read a tape after 
writing on that tape unless an intervening 
write ef or rewind instruction is given. 
(Both may be given if desired.) 

(c) It is not possible to write on a tape after 
reading that tape unless an intervening rewind 
instruction is given. 
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The fundamental machine cycle of the 701 is 12 
microseconds; the time required to execute an in¬ 
struction, or a sequence of instructions, is an integral 
multiple of this cycle. 

Table IV shows every operation of which the ma¬ 
chine is capable, together with the basic number of 
fundamental cycles required for its execution. The 
times shown specifically include obtaining, interpret- 
'ng, and executing the instruction. The actual number 
°f cycles required, however, is subject to modification 
under certain conditions. The third column of Table 
IV lists the class of modification, if any, pertaining to 
each operation. The four types of modifications are 
explained below. 

Type I. The instruction will be executed in two 
cycles less if a multiplication or division has been 
Performed in the preceding 12 instruction exe¬ 
cutions. 

Type II. The instruction will be executed in three 


TIMING 


cycles less if a multiplication or division has been 
performed in the preceding 12 instruction exe¬ 
cutions. 

Type III. The instruction will be executed in four 
fundamental cycles provided the extent of shift 
is 24 places or less, and provided a multiplication 
or division has not been performed in the preced¬ 
ing 12 instruction executions. Each additional 
eight places, or portion thereof, require another 
cycle. If a multiplication or division has been 
performed in the preceding 12 instruction execu¬ 
tions, then the instruction will be executed in 
two cycles for shifts of eight places or less. Each 
additional eight places, or portion thereof, re¬ 
quire another cycle. 

Type IV. The execution of this instruction mav 
be delayed an indefinite length of time after its 
interpretation, depending on the status of the 
input-output components. For example, if the 
execution of one tape read instruction is fol- 
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Table IV 


Operation 

Basic Number of 
Fundamental Cycles 

Modification 

Type* 

Stop and Transfer 

4 

I 

Transfer 

4 

I 

Transfer on Overflow 

4 

I 

Transfer on Plus 

4 

I 

Transfer on Zero 

4 

I 

Subtract 

5 

I 

Reset and Subtract 

5 

I 

Subtract Absolute Value 

5 

I 

No Operation 

4 

I 

Add 

5 

I 

Reset and Add 

5 

I 

Add Absolute Value 

5 

I 

Store 

5 

II 

Store Address 

5 

II 

Store Contents of jiq Register 

D 

II 

Load mq Register 

5 

II 

Multiply 

38 

none 

Multiply and Round 

38 

none 

Divide 

38 

none 

Round 

4 

I 

Long Left Shift 

4 

III 

Long Right Shift 

4 

III 

Accumulator Left Shift 

4 

III 

Accumulator Right Shift 

4 

III 

Prepare to Read 

4 

I and IV 

Prepare to Read Backward 

4 

I and IV 

Prepare to Write 

4 

I and IV 

Write End of File 

4 

I and IV 

Rewind Tape 

4 

land IV 

Set Drum Address 

4 

I 

Sense and Skip or Control 

4 

I 

Copy and Skip 

5 

IV 


*Note: A description of modification types may be found on page 47. 
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lowed by the interpretation of a second tape read 
instruction (for the same tape), the execution of 
the second read instruction will be delayed until 
the first record has been passed over. In the case 
of the copy instruction, the electronic and me¬ 


chanical equipment must be synchronized, and 
short delays may result for this synchronization 
to take place. In general, any execution delays of 
this type are of varying lengths, because the}’ 
depend to a great extent on the programming- 
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CARD READER 

Cards are read at the rate of 150 cards per minute. 
In continuous card reading, 292 milliseconds of the 
card cycle of 400 milliseconds are available for useful 
calculating. The difference, 108 milliseconds, is re¬ 
quired for the execution of the copy and read instruc¬ 
tions and appropriate time-margins for safe synchron¬ 
ization of mechanical and electronic components. 

The maximum safe times available for useful cal¬ 
culating between executions of copy instructions are 
indicated in Figure 10. For example, after execution 
of the 9-left copy instruction, 540 microseconds are 
available before the 9-right copy instruction must be 
given; and after execution of the 9-right copy in¬ 
struction, 15 milliseconds are available before the 
8 -left copy execution. The read instruction must be 
given in the hatched portion for continuous operation 
of the card reader. After the 12-right copy execution 
of a card, however, it takes 20 milliseconds before the 
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machine can execute a read instruction for the next 
card. If the read instruction, then, is given t milli¬ 
seconds after the 12-right copy, and if t is less than 
20 , the machine will compute (i.e., it will proceed 
with any intervening programs) for these t milli¬ 
seconds. Upon receiving the read instruction, how¬ 
ever, the program will be delayed until 20 milliseconds 
(from the 12-right copy) have elapsed. If the read 
instruction is given after the interval of 20 millisec¬ 
onds, the program will not be delayed. So to be able 
to compute for all of the available time between cards, 
and to keep the card reader in continuous motion, it is 
necessary to give the read instruction between 20 and 
70 milliseconds after the 12-right copy instruction. 

If the card reader is not in motion and a card read 
instruction is given, the average elapsed time between 
the read instruction execution and the first 9-left 
copy instruction execution will be 270 milliseconds. 
However, only 50 milliseconds are available for cal¬ 
culation after the read instruction execution. 
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CARD PUNCH 

Cards are punched at the rate of 100 cards per 
minute. In continuous card punching 442 milliseconds 
of the card cycle of 600 milliseconds are available for 
useful calculating. The difference, 158 milliseconds, is 
required for the execution of the copy and write 
instructions and appropriate time-margins for safe 
synchronization of mechanical and electronic com¬ 
ponents. 

The maximum safe times available for useful cal¬ 
culating between executions of copy instructions are 
indicated in Figure 11. For example, after execution 
of the 9-left copy instruction. 540 microseconds are 
available before the 9-right copy instruction must be 
given; and after execution of the 9-right copy in¬ 
struction, 31 milliseconds are available before the 
8-left copy execution. The write instruction must be 
given in the hatched portion for continuous operation 
of the punch. After the 12-right copy execution of a 
card, however, it takes 25 milliseconds before the ma¬ 
chine can execute a write instruction for the next 


card. If the write instruction, then, is given t milli¬ 
seconds after the 12-right copy, and if t is less than 
25, the machine will compute for these t milliseconds. 
Upon receiving the write instruction, however, the 
program will be delayed until 25 milliseconds (from 
the 12-right copy) have elapsed. If the write in¬ 
struction is given after the 25-millisecond interval, 
the program will not be delayed on this account; but 
the punch will already have disconnected, and a delay 
results. Thus, to be able to compute for all of the 
available time between cards, and to keep the punch 
running at full speed, it is necessary to give the write 
instruction at exactly 25 milliseconds after the 12- 
right copy instruction. 

If the card punch is not in motion, and a card 
write instruction is given, the average elapsed time 
between the wRiTE-instruction execution and the first 
9-left cOPY-instruction execution will be 400 milli¬ 
seconds. However, only 70 milliseconds are available 
for calculation after the WRiTE-instruction execution. 

Xot more than 24 copy instructions can be given 
per card cycle. 
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TIMING 


PRINTER 


Y/ifhout Echo Checking 

Information is printed at the rate of 150 lines per 
minute. In continuous printing, 322 milliseconds of 
the print cycle of 400 milliseconds are available for 
useful calculating. The difference, 78 milliseconds, is 
required for the execution of the copy and write 
instructions and for appropriate time-margins for safe 
synchronization of mechanical and electronic com¬ 
ponents. 

Maximum safe times available for useful calculat¬ 
ing between executions of copy instructions are in¬ 
dicated in Figure 12. For example, after execution of 
the 9-left copy instruction, 540 microseconds are 
available before the 9-right copy instruction must be 
given; and after execution of the 9-right copy in¬ 
struction, 13 milliseconds are available before the 
8-left copy execution. The write instruction must be 
given in the hatched portion for continuous operation 
of the printer. After the 12-right copy execution of a 


print cycle, however, it takes 16 milliseconds before 
the machine can execute a write instruction for the 
next cycle. If the write instruction, then, is given 
t milliseconds after the 12-right copy, and if t is less 
than 16, the machine will compute for these t milli¬ 
seconds. Upon receiving the write instruction, how¬ 
ever, the program will be delayed until 16 milliseconds 
(from the 12-right copy) have elapsed. If the write 
instruction is given after the 16-millisecond interval, 
the program will not be delayed. So to compute for 
all of the available time between print cycles, and to 
keep the printer running at full speed, it is necessary 
to give the write instruction between 16 and 115 
milliseconds after the 12-right copy instruction. 

If the printer is not in motion, and if a printer 
write instruction is given, the average elapsed time 
between the WRiTE-instruction execution and the first 
9-left COPY-instruction execution will be 280 milli¬ 
seconds. However, only 58 milliseconds are available 
for calculation after the WRiTE-instruction execution. 
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Figure 14 

Reading 

The maximum safe calculating time between suc¬ 
cessive copy executions is 540 microseconds. If the 
tape unit is not in motion, and if a tape read instruc¬ 
tion is given, 4 milliseconds are available for calcu¬ 
lating between the read execution and the first copy 
execution. If the read instruction for a second unit 
record is given t milliseconds after the execution of 
the last copy instruction of a first unit record, and if 
t tS 4, then 8 — t milliseconds are available for cal¬ 
culating between the read and first copy execution 
for the second record (Figure 15). If t > 4, then 4 
milliseconds are available. After tape rewinding, the 
maximum safe computing time between a tape read 
execution and the first copy execution is 300 milli¬ 
seconds. 

These allowable computing times also hold for 
reading backward. W hen a reversal of tape motion is 
made (reading forward, followed by reading back¬ 
ward) the available computing time between the read 
and copy executions stated above may be increased 
by 7 milliseconds. After the writing of an end-of-file 
gap, the maximum safe computing time between a 
tape read backward execution and the first copy 
execution is 500 milliseconds. 
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Summary 

Note that the multiplier-quotient register must not 
be used in the calculating between the read and the 
first copy executions, or between successive tape copy 
executions or for 1 millisecond following the execu¬ 
tion of the last copy instruction of a record. The 
delay instruction (write 2052) may be used to in¬ 
sure the latter condition. 

The following information may be used to find the 
over-all time required for the execution of a tape¬ 
reading or writing program. It should be kept in mind 
that these times should be used only {or estimations. 
The times for safe calculating described above must 
be strictly observed. 

1. If a tape is not in motion and if no reversal of 
previous motion is specified. 15 milliseconds is the 
maximum elapsed time between the execution of the 
read or write instruction and the execution of the 
first copy instruction. The average elapsed time will 
be 10 milliseconds. If a reversal of the previous mo¬ 
tion is specified, then the maximum time is increased 
to 27 milliseconds, and the average time is increased 
to 20 milliseconds. 

2. If tape writing of several records on a single 
tape is in process, the maximum elapsed time between 
the last copy execution of a given record and the first 
copy execution of the next record is 25, or 15 + t 
milliseconds whichever is greater, where t is the time 
between the last copy execution of the given record 
and the write execution of the next record. 

3. If tape reading of several records (with no re¬ 
versal of tape motion) is in progress, the maximum 
elapsed time between the last copy execution of a 
given record and the first copy execution of the next 
record is 18. or 8 + t milliseconds, whichever is 
greater, where t is the time between the last copy exe¬ 
cution of the given record and the read execution of 
the next record. 

4. For small records (less than five words) 1 mil¬ 
lisecond is a maximum elapsed time between copy 
executions. For records of more than five words the 
average time between copy executions approaches 
800 microseconds. 

5. After tape rewinding, the maximum elapsed 
time between a tape read execution and the first copy 
execution is 1.5 seconds. Average elapsed time is 0.9 
seconds. 












TYPE 701 AND ASSOCIATED EQUIPMENT. 


6. After tape rewinding, the maximum elapsed 
time between a tape write execution and the first 
copy execution is 1.2 seconds. Average elapsed time 
is 0.9 seconds. 

7. After the writing of an end-of-file gap, the 
maximum elapsed time between a tape read back¬ 
ward execution and the first copy execution is 1.2 
seconds. Average elapsed time is 0.9 seconds. 

MAGNETIC DRUMS 

Successive full-words are written on, or read from, 
the magnetic drums at the rate of about 800 words a 
second. More precisely, the average time of trans¬ 
mitting one word is 1.28 milliseconds. The maximum 
safe computing time between successive copy execu¬ 
tions is 1 millisecond. 

Any number of instructions (other than input-out¬ 
put instructions) can be executed between the drum 
read or write and set drum executions, and be¬ 
tween the set drum and the first copy executions. 

The execution of the first copy instruction is de¬ 
layed a length of time that depends on the drum 
address and on the elapsed time t between the read 


or write execution and the first copy interpretation 
The time delay T in milliseconds between the read 0t 
write execution and the first copy execution may 
determined approximately in this way: 

Divide the drum address by 32, forming an integer 
quotient Q and a remainder R. Let t be 30 or 
whichever is greater. Then 

m 7 i j i_ i 2 

T = t + d + —+ M 

where d is a time delay depending on the orien¬ 
tation of the drum. The d is not predictable but 
will not exceed 20 milliseconds, and averages 1C 
milliseconds. 

Thus, addresses 0, 32, 64, . . . are the most accessible 
addresses, and addresses 30, 62, 94, . . . are the least 
accessible addresses. For example, the formula above 
yields T = 40 milliseconds as the average access time 
to drum address 0000 if the copy instruction is giver, 
(by the program) 30 milliseconds or less after the 
read or write instruction. If the programmer is 
careful to store information starting at an address 
that is a multiple of 32, the average access time is 
very close to 40 milliseconds. The average random 
access time is e0 milliseconds. 
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CONTROL PANEL 

WIRING 


The card reader, card punch, and printer of the 701 
installation are modifications of the IBM Types 402, 
521, and 407, respectively. The following descriptions 
take advantage of similarities to the standard ma¬ 
chines. All new functions and features will be de¬ 
scribed in detail. Questions on how standard features 
operate can be answered by referring to the appro¬ 
priate principles of operation manual. 

In relation to the card reader and punch, note that 
a given copy instruction can read or set up punching 
for only 36 columns of a given card row, because a 
copy instruction can handle no more than a full word 
of 36 bits. The control panels for the card machines 
a re supplied with 72 entries to (or exits from) the 
calculator, corresponding to two full words in mem¬ 


ory or two half-rows on the card. Pulses from the 
card machine, synchronized with the passage of the 
card rows under the read brushes (or punch mag¬ 
nets), will cause first the left 36 entries (or exits) 
and then the right 36 entries (or exits) to be activated 
for each card row as the row passes under the read 
brushes (or punch magnets). The card columns can 
be wired to the calculator entry (or exit) hubs in 
any order. This section will assume that the first 72 
columns of the card are used and that the entries (or 
exits) from the calculator are .used in a normal left to 
right order. 

It is important to remember when reading this 
section that familiarity with wiring of the standard 
machines, of which the 701 components are modifica¬ 
tions, is assumed. 
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CARD READER 

Figure 16 shows the hubs on the control panel of the 
card reader and the wiring necessary to provide for 
a direct transfer of information from cards in the card 
reader to the calculator when the proper set of in¬ 
structions are provided by programming. 

Hubs not described in the standard manuals or 
hubs with different names will now be discussed. 

control brushes.- Equivalent to the second reading- 
brushes of the Type 402. 

read brushes: Equivalent to the third reading 
brushes of the Type 402. 
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Figure 16 


calc entry left and calc entry right: Entry hubs for 
pulses entering electrostatic storage from rows of the 
card. Successive copy instructions are associated 
alternately (by internal circuits) with first the left 
hubs then the right hubs, etc. Thus, with the wiring 
shown in Figure 16 it is seen that successive copy 
instructions will cause half-rows of the card to be 
read in the sequence described under Input-Output 
Components (i.e., 9-row left, 9-row right, etc.). The 
S hub for each of these groups accepts a pulse to de¬ 
termine the sign of the full word being entered, while 
the remaining hubs numbered 1-35 correspond to the 
other 35 bits of the full word. 

ON: These hubs must be connected for the card 
reader to operate as a component of the 701. 

Conditional transfer of information is possible 
through the use of selectors. The pilot selectors 
(which work in the same way as the Type 402 pilot 
selectors) have three sets of pickup hubs: immediate 
pickup (equivalent to the pickup function of the im¬ 
mediate pickup and coupling exit of the 402 ) ; 11-12 
pickup (equivalent to the X pickup of the 402) ; and 
the 9-12 pickup (digit pickup in the 402). 

The pickups can be activated directly from punch¬ 
ing in the card by wiring from control brushes to the 
appropriate pickup, as described in detail in the Prin¬ 
ciples of Operation of the Type 402 under the head¬ 
ing Pilot Selectors. In addition, each type of pickup 
can be activated by an impulse from a given set of the 
hubs described below. In most cases, whether a given 
pickup will he activated by a given hub can be decided 
on the basis of whether the equivalent 402 pickup 
would be activated. Cases that cannot be decided in 
this way will be described in detail under the appro¬ 
priate heading (below). 

By wiring the pilot selector coupling exits (similar 
to the coupling function of the immediate pickup and 
coupling exits of the 402) to appropriate co-selector 
pickups, one or more co-selectors can be picked up in 
unison with the pilot selector when the pilot selector 
is picked up with either the 9-12 pickup or the 11-12 
pickup. In this case, the co-selector, once picked up, 
will hold through the next cycle in the same manner 
as the pilot selector. 

The hubs that can activate the pickup hubs of se¬ 
lectors are, as on the 402, digit selector, split column 
control, and card cycles. These hubs emit pulses in 
exactly the same manner as the Type 402. 
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CARD PUNCH 

Figure 17 shows the hubs on the card punch control 
panel and the wiring required for punching informa¬ 
tion directly from the calculator into a card, when the 
proper sets of instructions are executed by the pro¬ 
gram. The example provides that information from 
the calculator be punched in columns 1-72 of the card; 
but, as in the card reader, it is possible to punch any 
arrangement of not more than 72 columns by means 
of appropriate wiring. The hubs involved in wiring of 
Figure 17 will be explained. 

punch magnets: These hubs have the same function 
as the corresponding hubs on the type 521. 

calc exit left and calc exit right: These are exit hubs 
for information being transmitted from electrostatic 
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Figure 17 


storage to the punch magnets. In relation to pro¬ 
gramming, the full word specified by the first copy 
instruction following the write instruction is avail¬ 
able at the calc exit left hubs. The full word 
specified by the second copy instruction is available at 
the calc exit right hubs. The left and right hubs 
then alternate for the following copy instructions. 
Because cards are fed 9's edge first, it is evident from 
the wiring in Figure 17 that the half-rows of the card 
will be punched in the sequence discussed under 
Input-Output Components (i.e., 9-row left, 9-row 
right, etc.). 

ca (calculate) : These hubs must be wired to enable 
the punch to operate as a component of the 701. 

The four selectors (two standard) of 10 positions 
each are picked up by means of the corresponding 
selector pickups, 1-4. Activation of the pickups di¬ 
rectly from the control brushes will be discussed later, 
using gang punching for illustration purposes. The 
selectors can also be picked up by electrical impulses 
available at the two sense output hubs in the upper- 
right section of the control panel. 

sense output hubs: Wiring a sense output hub to 
a selector pickup will allow a programmed sense in¬ 
struction with the proper address, to effect the transfer 
of a selector. With reference to Figure 11, a sense 
instruction given at any time after the first copy of a 
given cycle, and at least 32 milliseconds before the 
first copy of the next cycle, will cause the selector to 
be transferred shortly after the instruction is given 
(between 15 and 30 milliseconds later). The selector 
will then stay transferred until 20 milliseconds after 
the last copy of that next cycle. In normal usage the 
sense instruction is given soon after the write in¬ 
struction that initiates the cycle in which the selector 
is to be picked up. When all rows of a card are not 
being punched after a write instruction, any gang 
punching or emission of digits directed through selec¬ 
tors, which in turn are controlled by sense exits, re¬ 
quires special precautions to insure that the selector 
is transferred only during the cycles desired. As 
pointed out in Table II, the address of sense output 
hub number 1 is 1024, while number 2 is 1025. 

All other hubs on the panel operate in the same 
manner as on the standard Type 521. 
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Figure 18 


The card punch can be used for gang punching 
cards under calculator control as well as independ¬ 
ently of it. Figure 18 shows the wiring necessary for 
gang punching with interspersed master cards under 
calculator control (for this example the information 
to be gang punched is assumed to be in columns 75-80 
of the card). 

The control panel wiring as shown in Figure 18 is: 

1. Hubs S-35 of the calculator exit left hubs fol¬ 
lowed by hubs S-35 of the calculator exit right 
are wired to hubs 1-72 of the punch magnets. 

2. Columns 75-80 of the punch brushes are wired 
to five consecutive common hubs of selector 2. 
The corresponding normal hubs are wired to 
columns 75-80 of the punch magnets. 

3. The hub for control brush 1 (positioned at the 
column in which the control punch will be) is 
wired to selector pickup 2. 


4. The ca hubs are connected. 

If it is desired to gang punch cards independently 
of the calculator, the gp (gang punch) hubs should be 
connected instead of the ca hubs. 

If the program should call for the card punch to 
operate with the gp hubs wired, the calculator will 
stop, because no control by the program is possible 
with these hubs wired. 

Offset gang punching can be done in the normal 
way by wiring the appropriate control brush to the 
pc (punch control) hub and wiring the pd (punch 
delay) hub to the selector pickup. To prevent punch¬ 
ing in the master cards when offset gang punching, 
two selectors are necessary: one wired as above to 
provide for offsetting; the other wired to prevent 
punching the master card. For a .more detailed ac¬ 
count, see the section on Offset Gang Punching in the 
manual for the Type 521 reproducing punch. 

PRINTER 

The printer is used to print information contained 
in electrostatic storage. It should be emphasized that 
this printed material can be any combination of sev¬ 
eral characters. Some of the characters that can be 
made to print by means of impulses from electrostatic 
storage are decimal digits, letters of the alphabet, 
punctuation marks, dollar signs, etc. The IBM code 
for printing these characters is given in Table V. For 
example, a dollar sign (S) may be printed by arrang¬ 
ing impulses (from electrostatic storage) to arrive at 


Table V 

Character Code for the 701 Printer 
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CONTROL PANEL WIRING 
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Figure 19 


a print wheel at 11-time, 8-time, and 3-time of the 
print cycle. 

Figure 19 shows the control panel wiring for the 
Printer, with the wiring for an example to be ex¬ 
plained later. The hubs used for this example will now 
be explained in general terms. 

calc exit left and calc exit right: These hubs are exits 
for words being sent from electrostatic storage to the 
Printer by copy instructions. These two sets of hubs 
alternate with the copy instructions in the same way 
as similar hubs on the card punch. 

print entry: These are entry hubs for impulses to 
fbe individual type-wheels from electrostatic storage. 


print echo exit: These hubs are exits for the echo 
pulses generated by the type-wheel according to the 
character they are positioned to print. 

CALC ECHO ENTRY LEFT and CALC ECHO ENTRY RIGHT: These 
are hubs that can accept the echo impulses generated 
by the type-wheels. The copy instructions in the 
stored program then direct these impulses to electro¬ 
static locations in preparation for a programmed 
check. The left and right hubs alternate similar to the 
card reader. 

pr, ON: These hubs must be connected if the printer 
is to be used as a component of the 701. 
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zc: If these hubs are wired together, the zero print 
control function behaves exactly as in the 407. If these 
hubs are not wired, the type-wheels will print only if 
impulsed through the print entry hubs. 

Printing Control 

Example: The control wiring of Figure 19 pro¬ 
vides for printing any digit (including zero), letter, 
or special character that has been coded in the card 
image being copied. The wiring also provides for 
echo checking of the digits 9 through 1 in all positions 
except 11 and 64. In positions 11 and 64, provision is 
made for checking the special codes corresponding to 
the plus and minus signs (8, 3 and 8, 4). Printing 
from the card image will occur when the calculator 
executes a program similar to the one explained under 
Input-Output Components. Although this wiring is 
valid for printing any character, assume that binary- 
numbers will be printed here. 

In the specific example, characters being printed 
are separated into groups of three each to facilitate 
translation from the binary to the octal system. Any 
other arrangement could be accomplished. 

The control panel wiring shown in Figure 19 is as 
follows: 

1. The calculator exit hubs (two sets of hubs 
labeled S, 1-35: the left half-row and the right half¬ 
row, respectively) are wired to the print entry hubs in 
this order: 

CALC EXIT PRINT ENTRY 

S 11 

1.2 14,15 

Feft half-row 3,4. 5 17, 18, 19 

6,7,8 21.22.23 


CALC EXIT 

S 

1.2 
3,4. 5 
6, 7, 8 


33. 34, 35 
S 

1.2 


Right half-row 3, 4, 5 


57, 58, 59 
64 

67, 68 
70, 71, 72 


33, 34, 35 106, 107. 108 

2. The wiring from the calculator echo entry hubs 
(two sets of hubs labeled in the same way as the 
calculator exit hubs) to the print echo exit is the same 
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as that described in paragraph 1 above, if the words 
“calculator echo entry” and “print echo exit” are sub- 
stituted for “calculator exit” and “print entry,” re¬ 
spectively. Use of echo pulses is explained below. 

3. The zc hubs are wired. This allows the zero 
print control to operate in the same way as on the 
407. Note that all of the zero print control wiring, 
described in the next paragraph, could be eliminated 
if the zc hubs were not wired. The zero print control 
is brought into play here only to illustrate appropriate 
wiring. 

4. The pairs of zero print control hubs (described 
below) are numbered to correspond to the print entry 
hubs. All pairs of zero print control hubs correspond¬ 
ing to the print entry positions enumerated in para¬ 
graph 1 will be connected (i.e., the upper hub at a 
position is wired to the lower hub at the same posi¬ 
tion) except the pairs that are at the first of a sub¬ 
group (the hubs corresponding to positions 11, 14, 
17. 21, . . . 57. 64. 67, 70. . . . 106). The lower hubs 
at positions 14 and 67 will be wired to the zero entry. 
A further exception to the system described above 
occurs because the zero print control hubs should not 
be wired in groups of greater than 10 pairs of hubs. 
To separate the zero print control wiring into inde¬ 
pendent groups of appropriate size, the lower hubs of 
some positions are wired to zero entry. The remainder 
of the zero print control hubs at the first of a group 
will be connected diagonally from the lower hub of 
the pair to the upper hub immediately at the left (this 
corresponds to a blank position in the printing). 

5. The pr and on hubs are coupled. 

6. The space hub is wired to 1 to provide single 
spacing between lines of print. 

To check the printing of a number and its sign, the 
print echo exits corresponding to the print wheels 
that printed the number should be wired to the calcu¬ 
lator echo entries corresponding to the calculator 
exits from which the information was originally 
taken. It is then possible, by means of programming, 
to read these impulses into electrostatic storage and 
perform a programmed check on the original in¬ 
formation. 

In general the program for this checking relies 
upon the fact that the echo pulses occur in a given 
order: 8-4, 8-3, 9, 8, 7. 6, 5, 4, 3, 2. 1. Each print 
wheel emits an echo pulse timed to indicate the sector 
within which it was set up to print. Since no provision 
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example, at 8-echo time, the print echo exits, corre¬ 
sponding to the print wheels set up to print in the 8 
sector, will emit a pulse. The program will copy these 
pulses into memory in the form of a binary word 
which can then be compared with the word in the 
card image corresponding to the 8-row. 
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zero print control: By means of the zero print con¬ 
trol hubs on its control panel, the 701 printer can 
provide any one of a number of responses to zeros or 
any symbol not having a digit pulse. Each pair of zero 
print control hubs corresponds to a print entry posi¬ 
tion ; the manner in which the pair of hubs is wired to 
its neighbors controls the printer’s response. Zero 
print control functions only during zone (0, 11, 12) 
time and .V (no-zone) time and can have no effect 
upon the printing in a position that has received a 
digit impulse (1 through 9) during a given print 
cycle. Thus, the only special characters that can be 
controlled are those consisting only of zone pulses 
(the zero, check-protecting asterisk, plus sign, and 
minus sign) or those emitted from special hubs on the 
control panel (the dollar sign, period, and comma). 
The specially emitted symbols provide for setting the 
print wheel to the proper sector without use of the 
usual combination digit punching (as an 8 and a 3 in 
the case of the dollar sign, period and decimal point, 
and comma). The dollar sign, period, and comma can 
be printed with the usual combination punching, of 
course, but in this case the symbol cannot be con¬ 
trolled by means of zero print control. 

Note that zero print control hubs cannot operate 
correctly when used in groups of more than ten at a 
time. Groups larger than this should be split and 
wired independently. 

Examples and applications of zero print control 
are given under the heading Zero, Comma, Decimal 
and Dollar Symbol Control in the Type 407 principles 
of operation manual. 
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filter in-out: These hubs permit the passage of an 
impuls'e in only one direction—into the in hub and 
out of the out hub. The out hub of one filter should 
not be wired to the in hub of another filter, either 
directly or indirectly. 

The printer has ten pilot selectors, each of which is 
Picked up by an associated one of the pilot selector 
pickups (these pickups are similar to the immediate 
fu hubs on the Type 407). In addition, there are 20 


co-selectors, each with two identical co-selector pick¬ 
ups. The co-selectors can be picked up in unison with 
given pilot selectors by wiring the appropriate pilot 
selector coupling exits to the co-selector pickups, or 
the co-selector can be picked up independently by 
direct wiring from other hubs. The pilot selectors and 
co-selectors are similar, in action, to the pilot selec¬ 
tors and co-selectors of the card reader. Hubs that 
provide pulses to activate the selectors through their 
pickups are: 

alteration switches. These switches function in the 
same way as the 407 alteration switches, by emitting 
a pulse every machine cycle when the corresponding 
toggle switch on the printer has been turned on. 
These pulses can be used to pick up either pilot selec¬ 
tors or co-selectors. 

split-column control.- These hubs perform the same 
function as the 407 split column control. The numbers 
on either side of a given hub of the split column con¬ 
trol refer to the corresponding print times. A selector 
pickup wired from a given one of these hubs (the hub 
between numbers 8 and 7) will cause the selector to 
be transferred between the corresponding print times 
(the selector would be transferred after 8-time and 
before 7-time). 

print cycles: These hubs are similar in use to card 
cycles of the Type 407. A pulse is emitted from these 
hubs during every machine cycle of the printer. 

sense exits: Exits 1 through 10 are addressed by 
the numbers 0512 through 0521, respectively (Table 
II). By programming a sense instruction with one 
of these addresses, an impulse is made available at the 
corresponding exit hub. This pulse can then be used 
to pick up pilot selectors. If the exit is wired in this 
way, the normal usage is as follows: if the sense in¬ 
struction is given during the hatched portion of Fig¬ 
ure 12, the pilot selector will be transferred for the 
duration of the cycle initiated by the write instruc¬ 
tion that also is given during the hatched portion of 
Figure 12. sense instructions given at times in the 
machine cycle other than those specified above may 
have no effect. (Additional uses of sense exits are 
discussed below under Carriage Controls). 

Carriage Control 

The carriage of the printer is usually controlled by 
means of a punched paper tape (the control tape) 
used in combination with the ten sense exit hubs. 
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(For some simple applications, such as line-by-line 
printing, the carriage can be directly controlled with¬ 
out the use of the control tape.) In brief, the control 
tape is utilized as follows: 

The tape is cut to the length of the form to be used 
(and later glued into a loop to provide for repetitive 
operation) ; punched holes in the tape thus correspond 
to positions on the form. When the carriage is in 
operation, the tape advances in synchronism with the 
form. An impulse to a given carriage skip hub (num¬ 
ber 4) will cause the form to skip until the control 
tape—and consequently the form—reaches the posi¬ 
tion where there is a punched hole in the channel 
(column) corresponding to the impulsed hub (chan¬ 
nel). 

For a detailed description of the above points and 
for a further description of the carriage manual con¬ 
trols (restore key, space key, etc.), see the principles 
of operation manual for the Type 407. 

The hubs listed below, when impulsed from the 
carriage control hubs, activate the various carriage 
skips and spacings. It should be kept in mind, when 
reading the descriptions of these hub functions, that 
an automatic space is initiated, but not automatically 
terminated, before each line of printing, except before 
printing the first line immediately after skipping. Be¬ 
fore the first line of printing or in the cycle immedi¬ 
ately after a skip, no normal spacing takes place. 

carriage skips: These hubs are similar to the d hubs 
of the Type 407 carriage skips. For example, a 
pulse to carriage-skips hub 1 will initiate a form skip 
that terminates when the first punch in channel 1 
passes under the control-tape read brushes. In gen¬ 
eral, a hole punched in a given channel of the tape 
stops the form at a predetermined position after a 
pulse to the corresponding carriage-skips hub has 
started a form skip. The ten channels in the tape (in 
conjunction with the ten corresponding carriage 
skips) provide for an almost unlimited number of 
combinations of such skips. Because tape length and 
form length are equal, it is easy to make the punches 
in the tape correspond to the predetermined positions 
on the form). 

By wiring sense exits to carriage skips and by 
punching the various channels in the tape to corre¬ 
spond to various sequences of printing on the forms, 
it becomes possible for stored programs (in electro¬ 
static memory) to maintain an extremely flexible 
control over the printed output. 


short skip: These hubs are similar to the short-skip 
hubs of the Type 407. The short-skip hubs provide 
for skipping with no interruption of printing. The 
hubs can be used wherever there occurs an over¬ 
flow of less than one inch or a regular skip of less 
than two inches. Any impulse used to initiate a short 
skip (e.g., a sense-exit impulse used to cause a skip 
of less than two inches) should be wired first to a 
short-skip hub and from there to its ultimate destina¬ 
tion (a carriage-skip hub) . As a result of such wiring, 
printing will continue at the normal rate of 150 lines 
per minute during short skips. 

space-sel (selective space) : These hubs are similar 
to the selective space hubs of the Type 407. When 
connected, the two selective space hubs allow spacing 
of less than seven lines to be selectively controlled by 
punches in channel 11 of the control tape. The action 
is such that, before each line of printing, spacing is 
automatically started; a punch in channel 11 then 
stops the spacing. For spacing of less than three lines 
it is necessary only to connect the selective space hubs 
and punch the desired positions in the control tape. 
For spacing of more than three lines (but less than 
seven lines), it is also necessary to impulse the space 
suppress and extra space hubs from print cycles 
(space suppress and extra space are discussed below). 

extra (extra space) : These hubs are similar to the 
extra-space hubs on the Type 407. These hubs are 
usually used in conjunction with the space 1 or the 
space 2 hub. When space 1 is wired and an extra¬ 
space hub is impulsed (by a print cycles pulse, for 
instance), an extra single space results. With space 2 
wired, an extra double space results. 

suP: Similar to the space suppress hubs of the Type 
407. If one of these hubs is impulsed (by a print 
cycles for instance), all normal spacing will be sup¬ 
pressed during the cycle in which the hub was im¬ 
pulsed. 

NP: Similar to the non-print hubs of the Type 407. 
The xp hubs will suppress both printing and spacing, 
regardless of other control panel wiring, for the cycles 
in which they are impulsed by a print cycles pulse. 

The three types of hubs to be described below may 
be used to control the carriage. It should be noted that 
impulses available from these hubs may be directed 
through various selectors to provide controlled varia¬ 
tions in form spacing from print cycle to print cycle. 
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sense exits: A given one of these hubs emits a pulse 
when a sense instruction, with the appropriate ad¬ 
dress, is executed. (See the previous discussion of 
sense exits in this section.) These hubs can be wired 
to carriage skip hubs, thus providing the stored pro- 
o-ram in the calculator with a means of controlling 
form spacing. When the sense exits are to be used for 
this purpose, the corresponding sense instruction 
should be given immediately after the write instruc¬ 
tion that starts the print cycle. 

ovfl: Similar to the Type 407 overflow hub. This 
hub emits a pulse whenever a punch in channel 12 
of the control tape passes the control tape reading 
brushes. The pulse emitted by this hub lasts (Figure 
12) through the hatched portion of the cycle, after 
the cycle during which overflow has occurred (this 
fact will be of use in discussion of the sense-entry hub 
below). The overflow hub is often wired to a carriage- 
skips hub. thus providing a skip from the position at 
which channel 12 was punched to the position of the 


first punch encountered in the channel corresponding 
to the carriage skips hub. Such wiring is usually used 
to overflow to another form when the bottom of a 
iven form is reached. 

se (sense entry) : The sense-entry hub is an input 
hub on the printer control panel that can be sensed by 
a sense instruction with address 0522 (see Table II). 
If during the execution of such a sense instruction, 
the sense-entry hub is being impulsed, the sense in¬ 
struction will skip over the next instruction in the 
stored program. If the hub is not being impulsed 
when the sense instruction is executed, the stored 
program will continue without skipping. The sense 
entry is intended primarily to be used with the over¬ 
flow hub to inform the stored program when a form 
overflow is occurring. To accomplish this, the over¬ 
flow hub is connected to the sense entry hub and a 
sense instruction is given sometime within the por¬ 
tion of the print cycle in which the overflow hub is 
emitting a signal (see above paragraph). 
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MANUAL CONTROL 
OF COMPONENTS 


CARD READER 

To prepare the card reader for control by the cal¬ 
culator. once the control panel is in place, it is neces¬ 
sary only to fill the hopper with cards and hold the 
start button until the ready light goes on. Figure 20 
shows the card path through the card reader, and 
indicates the relative locations of the card levers, con¬ 
tacts, and reading brushes as cards move through the 
reader under control of the stored program. After the 
card reader has been prepared for calculator control 
and the ready light is on, there will be two cards in 
the reader, and all three card contacts (upper-card 
lever, lower-card lever, and hopper contact) will be 
closed. 

Buttons and Lights 

Start Button: Serves to run-in cards initially and 
to turn control of the card reader over to the calcu¬ 
lator. The button is operative only if: the power is 
on, no fuses are blown, there is no card-feed failure, 
the stacker is not full, the control panel is in place, 
and the control panel calculator switch is wired on. 

If there is no card waiting ahead of the read 
brushes, pressing the start button causes the card feed 
to operate for one or more card cycles until either the 


button is released or until the card enters the station 
just ahead of the read brushes. When the first card 
reaches the station ahead of these brushes, the start 
button causes control to be turned over to the calcu¬ 
lator and the ready light to go on. 

If there is a card waiting ahead of the read brushes, 
pressing the start button merely turns control over to 
the calculator, and the ready light is turned on. 

If there are no cards in the hopper or in the card 
feed ahead of the read brushes, pressing the start 
button turns on the running light and allows the cal¬ 
culator to set up an end-of-file condition. 

While the ready light is on, the start button cannot 
be used to feed cards. 

Stop Button: Causes the calculator to lose control 
over the card reader, and turns off the ready light. 
If a card is being read at the time the stop button is 
pressed, the action is delayed, and the card reader 
does not stop until the end of the current card cycle. 
The calculator will then be held up on the next copy 
instruction that refers to the card reader. 

Feed Button: Permits cards to be run out of the 
card feed manually when the card reader is not under 
control of the calculator. 
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Figure 20 


If the power is on, no fuses are blown, the stacker 
is not full, and the ready light is off (indicating that 
the calculator does not have control), pressing the 
feed button causes the card feed to operate for one or 
more card cycles until the button is released. 

While the ready light is on, the feed button is in¬ 
operative. The stop button may be used to turn off the 
ready light in order to operate the feed button. 

Ready Light: Indicates that the card reader is 
under control of the calculator. The ready light is 
turned on by the start button. It is turned off as 
follows: 

1. By the stop button. 

2. When the lower card lever is open at the end of 
a card cycle. 

3. When the hopper contact opens at the end of a 
card cycle (after which it may be turned on 
again by means of the start button). 

4. When there is a card-feed failure. 

5. When a fuse is blown. 

6. When the power goes off. 

7. When the control panel is removed. 

8. When the stacker is full. 

The hopper contact opens when the hopper runs out 

cards. This turns off the ready light and stops the 
Car d reader. The card reader can be started again by 


pressing the start button, regardless of whether more 
cards meanwhile were placed in the hopper. 

Select Light: Goes on when the calculator gives 
a read instruction for this card reader. The light goes 
off when the card cycle called for by the read instruc¬ 
tion has been executed. 

Card-Feed Stop Light: Is on whenever there is a 
card-feeding failure. 

Power-on Light: Indicates that the DC power is 
on in the card reader. 

Fuse Light: Indicates a blown fuse, if the main 
power is still on. 

Card-Feed Failure 

When a card-feed failure occurs, the card-feed stop 
light is turned on. The start button is inoperative 
until a certain procedure is accomplished. The pro¬ 
cedure : 

1. Remove all cards from the hopper. (Note that 
this opens the hopper contact and turns off the 
ready light.) 

2. Run out the cards in the feed by means of the 
feed button. 

3. Then press the stop button. 
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The last card in the stacker will not have been read. 

The stop button will not reset the card-feed stop 
light if there are still cards in the hopper or in the 
feed ahead of the read brushes. 

End-of-Cards Procedure 

When the last card in the hopper is fed, the hopper 
contact (Figure 20) opens, the calculator stops, and 
the ready light is turned off. 

If, at this point, there are more cards for the card 
reader to read, it is necessary only to reload the 
hopper and press the start button. The calculator will 
then read the cards in the hopper as if they were a 
continuation of the previous sequence of cards. 

If, on the other hand, the card hopper is left empty 
when the start button is pressed, it is an indication 
that the end of the card file has been reached. In this 
case, pressing the start button will again return con¬ 
trol to the calculator, but as the last of the remaining 
cards passes the read brushes, the calculator sets up 
an end-of-file condition; this provides a means of con¬ 
trol as described under Input-Output Components. 

CARD PUNCH 

Buttons and lights on the punch are similar to the 
corresponding controls on the card reader. Conse¬ 
quently, the discussion of punch controls will be of a 
general nature. Details peculiar to the punch, how¬ 
ever, will be explicitly discussed. Note particularly 
that there is no end-of-file condition on the punch. 

To turn control of the card punch over to the cal¬ 
culator (once the control panel is in place with the 


calculator hubs connected) the hopper is filled with 
cards, and the start button is held until the ready light 
goes on. There will now be one card in the punch; 
the hopper contact and the die-card-lever contact 
(Figure 21) will be closed. When an appropriate pro. 
gram is executed by the calculator, the first card that 
was in the hopper will now be punched with informa¬ 
tion from electrostatic storage. 

The path of the cards through the punch is shown 
in Figure 21, along with the relative locations of the 
card levers, brushes, and punches. If, for any reason, 
one of the card contacts is not closed, the ready light 
will be turned off. The ready light is also turned off 
by any of the following conditions in the card punch: 
power off, blown fuse, full stacker, control panel not 
inserted, gang-punch switch wired, or a double punch 
or blank column if the panel is so wired. 

If the control panel has been so wired, the double 
punch or blank column in any of the columns being 
checked will turn on the double-punch blank-column 
light and turn off the ready light. To reset the double¬ 
punch blank-column light, press the stop button. Con¬ 
trol can then be returned to the calculator by pressing 
the start button. 

If the gang-punch (gp) switch on the control panel 
is wired, the ready light cannot be turned on; so the 
calculator will have no control over the card punch. 
The punch can now be used as a gang punch in the 
usual way. 

If the control panel has been wired for gang punch¬ 
ing with the calculator switch on the control panel 
wired, the operation will depend upon the condition 



Figure 21 
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of the ready light. If the ready light is on, then each 
card fed under calculator control will be gang punched 
in accordance with the panel wiring. (The feed button 
under this condition is inoperative.) If the ready light 
is off, then gang punching will take place as long as 
the feed button is depressed; the feed button must be 
held down, for as soon as the feed button is released, 
the punch stops at the end of the next card cycle. 

Should the card punch run out of cards, the hopper 
contact opens, and the ready light is turned off. 


PRINTER 

Buttons and lights on the printer are similar to those 
on the card reader, with the following exceptions: 

1. The feed button is replaced by a print-cycle 
button. 

2. The card-feed stop light is replaced by a form- 
stop light. 

3. The STOP BEFORE PRINTING, TEST, and FORM 
stop switches are added. 

Consequently, a general discussion of printer con¬ 
trols will be discussed with special emphasis on the 
different features. 

To prepare the printer for control by the calculator 
once the control panel is in place—it is necessary 
onh to hold the start button until the ready light goes 
on. The ready light will be turned off by any of the 
following conditions: test switch on; a form stop, 
indicated by the form-stop light, when the form-stop 
switch is on; depressed stop button on the carriage; 
depressed stop button on the printer; power off; 
blown fuse. (The test switch is discussed below.) If 
the form-stop switch is on, the form-stop light goes 
on when the printer runs out of paper. Other carriage 
controls are similar to controls on the Type 407 
carriage. 

As in the card reader and card punch, the printer 
stop button gives the operator a means of holding up 
printing whenever he so desires. The carriage stop 
button has an equivalent effect. 

Turning the test switch on causes the ready light 
to go off. 

The print cycle button will start a print cycle only 
under the following conditions : 

1. When the ready light is off (as when the test 
switch is on). 

2. When the ready light is on, the stop-before¬ 
printing switch is on, and the program supplies 
a read or write instruction for the printer. 


With the test switch on, the ready light is off. De¬ 
pressing the print cycles button will cause the printer 
to go through print cycles until the button is released. 
If it is desired to switch control back to the calculator, 
the test switch must be turned off and the printer 
start button pressed. 

With the stop before printing switch on, the 
printer, after being selected by a read or write in¬ 
struction in the program, is held up at the first copy 
instruction. Depressing the print cycles button will 
cause the printer to print one line and the calculator 
to proceed with the program until the next group of 
output instructions for the printer are readv to be 
executed. 


MAGNETIC TAPE UNITS 

After a new tape reel has been inserted, the forward 
direction button is pressed. (This button sets up the 
tape unit to run forward on manual operation of the 
load-unload-rewind button or the feed button, i Then 
pressing the load-unload-rewind button causes the 
tape to advance to the proper starting point for auto¬ 
matic operation; at this point the tape stops automati¬ 
cally. Closing the door of the tape unit permits the 
operator to turn control of the tape unit over io the 
calculator. 

To unload a tape after it has been used, the door is 
opened (this prevents the calculator from interfering- 
with manual operations) and the backward di¬ 
rection button is pressed. If the tape is not already 
rewound, this can be done by use of the load-unload- 
rewind button that is set up for rewinding or unload¬ 
ing by the backward button. After the tape has been 
rewound to the unload position, the tape can be re¬ 
moved from the tape unit. 

As a safety precaution, the tape drive is completely 
disabled while the tape stop bar is depressed. This 
prevents any accidental operation of the buttons. 

The door of the tape unit should not be opened 
while the tape unit is in automatic operation. This 
may wreck the problem being run, especially when the 
tape unit is in write status, as indicated by the writ¬ 
ing light being on. Unless the file being written is 
already in error and cannot be used any wav, one 
should never open the door when the writing light 
is on. 

The stop bar on the tape unit may be used for an 
emergency stop. 














SUMMARY 


MACHINE CHARACTERISTICS 

General 

Parallel operation. 

Binary notation internally. 

Word Size 

Either 36 bits or 18 bits, including sign. 

Instructions 

Single address system. 

32 distinct operations. 

Instructions are 18-bit words. 

Computing Speed 

More than 2000 multiplications per second on full- 
word factors. 

Electrostatic Storage 

Capacity: 2048 words of 36 bits each. 

Each full-word location may be split into two half¬ 
word locations with the capacity of 18 bits. 


Magnetic Drums 

Four drums, each with the capacity of 2048 words 
of 36 bits each. 

Average access time to first word of block: 40 mil¬ 
liseconds. 

Rate of reading or writing: 800 full words per 
second. 

Magnetic Tapes 

Four magnetic tape units. 

Material: Oxide-coated non-metallic tape, p 2 inch 
wide. 

Maximum length per reel: 1400 feet. 

Recording in 7 parallel channels, 6 channels for in¬ 
formation and one for redundancy checking. 

Tape may be written forward, read forward, or 
read backward, under control of the program' 

Density within a unit record: 200 words per foot. 

Distance between unit records: one inch. 

Average time of acceleration to reading or writing 
speed: approximately 10 milliseconds. 

Rate of reading or writing a unit record : 1250 full 
words per second. 
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Page Printing 

One printer. 

Speed: 150 lines per minute with up to 72 com¬ 
puted characters per line. 

Printing is possible in any number system. Conver¬ 
sion accomplished by programming simultane¬ 
ously with printing. 

Alphabetic and special symbols may also be printed. 

Stored program may be used to control printer. 

Card Reading and Punching 

One card reader and one card punch. 

Read or punch up to 72 card columns. 

Reading rate : 150 cards per minute. 

Punching rate: 100 cards per minute. 

Cards punched in standard IBM decimal code can 
be read at full speed and converted simultane¬ 
ously by means of a program. 

Can read or punch in binary code with 24 full 
words to a card at full speed. 

Stored program may be used to control punch. 

Manual Control 

Operator's panel. 

Control panels for each component. 

Buttons and switches on components. 

Checking 

Tape reading and writing checked by redundancy 
check. 

Printing checked by echo signals. 

Decimal card punching checked by double-punch 
blank-column detection. 

Calculation duplication by programming. 

Mathematical and physical checks by programming. 


INSTRUCTIONS 


Decimal 

Code 

Abbre¬ 

viation 

Name of Operation 

00 

STOP 

Stop and Transfer 

01 

TR 

Transfer 

02 

TR OV 

Transfer on Overflow 

03 

TR + 

Transfer on Plus 

04 

TR 0 

Transfer on Zero 

05 

SUB 

Subtract 

06 

R SUB 

Reset and Subtract 

07 

SUB AB 

Subtract Absolute Value 

08 

NO OP 

No Operation 

09 

ADD 

Add 

10 

R ADD 

Reset and Add 

11 

ADD AB 

Add Absolute Value 

12 

STORE 

Store 

13 

STORE A 

Store Address 

14 

STORE MQ 

Store Contents of mq Register 

15 

LOAD MQ 

Load mq Register 

16 

MPY 

Multiply 

17 

MPY R 

Multiply and Round 

18 

DIY 

Divide 

19 

ROUND 

Round 

20 

L LEFT 

Long Left Shift 

21 

L RIGHT 

Long Right Shift 

22 

A LEFT 

Accumulator Left Shift 

23 

A RIGHT 

Accumulator Right Shift 

24 

READ 

Prepare to Read 

25 

READ B 

Prepare to Read Backward 

26 

WRITE 

Prepare to Write 

27 

WRITE EF 

Write End of File 

28 

REWIND 

Rewind Tape 

29 

SET DR 

Set Drum Address 

30 

SENSE 

Sense and Skip or Control 

31 

COPY 

Copy and Skip 

-13 

EXTR 

Extract 


New units are described on page 70. 
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NEW UNITS 

Type 727 Tape Units 

The standard tape units for the Type 701 have 
been the Type 726 tape units described in detail in 
this manual. However, Type 727 tape units are avail¬ 
able for use with the Type 701. One Type 753 con¬ 
trol unit is required for use with the Type 727 tape 
units. These tape units are the standard tape units 
for the Types 702, 704, and 705, and give these com¬ 
puters magnetic tape compatibility for. ease of inter¬ 
computer communication. The Type 727 tape units 
are described in the manuals for the 702, 704, 
and 705. 

Several peripheral components are available with 
use of Type 727 tape units. These components are: 
Magnetic tape to printer 
Magnetic tape to punched cards 
Punched cards to magnetic tape 
These are referred to as “peripheral'-' components be¬ 
cause their operation is completely independent of 
the operation of the computer. 


Type 740 CRT Output Recorder 

The Type 740 CRT Output Recorder is available 
for use with the 701. The Type 740 permits the dis¬ 
play of output information in the form of points on 
the faces of two cathode ray tubes. Digital informa¬ 
tion in es storage is automatically converted to 
analog information in the 740, and this analog in¬ 
formation is displayed in the form of intensified spots 
on the crt’s. 

A camera is attached to the smaller of the two 
tubes, so that a permanent film recording may be 
made of whatever appears on the face of that crt. 
The larger CRT is used for immediate visual observa¬ 
tion. The conversion from digital to analog data, the 
display of spots on the face of the tubes, and the 
operation of the camera are all done at electronic 
speeds under control of the calculator. Curves and 
alphanumerical characters are generated as successive 
point displays where each point is represented in es 
storage by a pair of rectangular coordinates. 












PROGRAMMING 


This section is intended primarily to give the rela¬ 
tive beginner an understanding of some of the basic 
techniques of programming. It is impossible to cover 
all aspects of programming, because machine versa¬ 
tility permits a programmer to handle a problem in a 
variety of ways, one of which is most efficient. The 
conventions and techniques to be described have been 
in use with a 701 installation, but do not necessarily 
represent the most desirable or most efficient methods. 
It is hoped, however, that these paragraphs will point 
to a greater understanding of 701 programming and 
its simplicity. 

CONVENTIONS AND SYMBOLISM 

A portion of memory capable of retaining a word is 
termed a location or a cell. As mentioned in Part I, 
these locations are identified by individual addresses 
that range from 0000 to 4095 as far as electrostatic 
memory is concerned. Consequently, the twelve bits 
of the address part of an instruction are interpreted to 
be an integer. The five bits of the operation part of an 
instruction are also regarded as an integer. With the 
address part represented by an integer y where 
0 ^ y < 2 1 - 


and the operation part represented by an integer x 
where 

0 ^ x < 2 5 

the entire instruction is represented by an integer i 
i = ± (.r • 2 X - + y ) 

In other words, the address part alone is thought 
of as an integer. Similarly, the operation part, when 
thought of by itself, is regarded as an integer. And 
finally, the instruction as a whole is thought of as an 
integer. Thus, when modifying instructions by simple 
additions, the binary point is assumed to be between 
accumulator positions 17 and 18. 

It is convenient to express addresses as decimal 
integers since the decimal system is most familiar. 
For ease in reading programs, alphabetic abbrevia¬ 
tions are used as operation parts. For example, the 
instruction 

— add 1492 

means add the contents of full-word location 1492 to 
the contents of the accumulator. Of course, the deci¬ 
mal addresses and the operation abbreviations must 
be converted to binary information before interpreta¬ 
tion by the 701. Decimal-to-binary conversion i s 
readily accomplished by the 701 itself, however, and 
may be made a part of a standard library of programs- 
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PROGRAMMING 

Examples of programming will be given in a standard form. An instruction 
given in this form is shown below. 


LOCATION 

INSTRUCTION 

REMARKS 

± 

Operation Part 

Address Part 

+ 1066 

— 

R ADD 

10 

1492 

Place the contents of cell —1492 
in the accumulator 


In the example above. +1066 is the cell in which the instruction is stored. The 
minus sign pertains to the sign of the instruction itself; a plus sign is implied if 
this column is left blank. The operation part consists of the alphabetic abbrevia¬ 
tion and decimal code for the operation. The address part contains the address 
of the operand. Thus, the number actually appearing in cell -1066 is 

-101492. 

Because, in describing a program, it is frequently necessary to refer to a 
particular cell (or location) in memory, the phrase ‘‘cell a " is used to mean 
the cell whose address is the integer a." Thus, the phrase "1 '10 is retained in 
cell —1492 means "1 10 is retained in the cell identified by the address —1492.” 
This type of [)hrase frequently will be further abbreviated to 

L(- r) = (7. 

by which is meant “the location of the quantity .r in memory is the cell whose 
address is a." So, using the same example, 

22(1/10) = -1492. 

Similarly, it is frequently necessary to refer to the quantity or word stored in 
a particular location. The quantity or word stored is usuallv referred to as "the 
contents of the cell" (e.g„ “the contents of cell -1492 is 1/10"). The notation 

C00 = -r 

means “the contents of cell a is the quantity ,r," e.g.. 

C( —1492) = 1/10 

The symbols L and C are reciprocal. By the definitions, then, 

L[C (<?)] = a 
and 

C[L (.r)] = 


Instructions and remarks may be written with this notation : 


LOCATION 

INSTRUCTION 

REMARKS 

± 

1 Operation Part 

Address Part 

1066 

1067 

— 

R ADD 

STORE 

10 

12 

L(1/10) 
1494 

Place 1/10 in the accumulator 

C( —1494) is replaced by 1/10 


^ ote in the above program that the actual array of binary digits that represent 
/10 is not precisely specified, since position of the binary point is not specified. 
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However, the use of the L and C symbols in connection with instructions or 
instruction modification is precise because of the convention to regard instruc¬ 
tions as integers. Thus, in the program 


LOCATION 

INSTRUCTION 

± 

Operation Part 

Address Part 


1063 


R ADD 

1 10 

L(0) 


1064 


. store a 

; 13 

1068 


1065 


read 

I 24 

0256 

1021 

—>1066 


R ADD 

10 

1068 


,—>1067 


SUB 

09 

L(2) 


- -1068 

— 

COPY 

31 

[ ] 

1 

1069 


STORE A 

13 

1068 

1 

—1070 


TR 

01 

1067 


- >1071 






REMARKS 


Modify the copy instruction 


the execution of instruction 1067 increases the address part of the instruction in 
the accumulator by 2, or equivalently, by a binary 1 in accumulator position 16. 
The symbol L(2), used in the above program, represents an application of the 
following convention. 

Assume the symbol = L(. r) where the + or — designates either a half or 
full word. 


Rule 1. If x 2? 1 the binary point of the word is assumed to be 
to the right of the rightmost position of the word. 

Rule 2. If x < 1 the binary point of the word is assumed to be 
to the left of the leftmost position of the word. 

Examples: 

The contents of + L(—2) are 
-00000000000000010 

The contents of — L( + l) are 

+00000000000000000000000000000000001 

The contents of — L(+2 _2 )are 

+01000000000000000000000000000000000 

The contents of + L(+2 -3 ) are 

+00100000000000000 

The contents of — L(+2) equals the contents of — L{ 2 -34 ) equals 

+00000000000000000000000000000000010 

When an instruction or address part is modified by computation, the computed 
instruction or instruction part is enclosed by square brackets. (See instruction 
1068 above.) 
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Arrows are drawn to the left of the instructions to indicate the action of the 
transfer instructions, as in the program above. Dotted arrows are drawn to 
indicate the action of copy or sense skips. If it is not possible to draw lines to 
indicate a transfer (such as may happen when a program is on two or more 
pages) the notation above on instruction 1066 is used. The number and arrow 
to the left of 1066 mean that the instruction in cell 1066 can be executed as a 
result of a transfer instruction in cell 1021. 

For simple exposition it frequently is not convenient to write actual addresses, 
as 1492 or 1066, above. A symbol, such as a Greek or Roman letter, may also 
be used to represent an address where the correspondence to a particular address 
is arbitrary or not yet assigned. For example, consider the following program: 


INSTRUCTION 

T or \ 'rTrv\T 

REMARKS 

| i-VU.A I lUiN 

! 

Operation Part 

Address Part 

i 

a . - 

a-r 1 — 

R ADD 

STORE 

10 

12 

1492 

1494 

Duplicate the contents of cell 
-1492 in cell -1494 


\\ ith this notation it is possible to refer to the instruction a (i.e., the instruction 
stored in some cell a) without actually specifying where the program is to be 
located in memorv. 

A subscript is used to indicate the base of a number when the context is not 
clear: Thus 

(1101):! = (15). = (13) 10 

represent the same number to the bases 2, 8, and 10, respectively. 


In text involving card input the following notation has been adopted. The 
word obtained by the first copy execution is designated by 9 L to indicate the left 
portion of the 9 s row; the word obtained by the second copy execution is 
designated by 9;,,, and so on ; the last word of the card image is designated by 12 A . 
for the right portion of the 12-row. 
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SUB-PROGRAMMING DEVICES 

The devices to be described illustrate some of the 
general techniques in programming. They represent, 
however, only a few of many such devices. 

Basic Linkage 

This method has, in general, been found to be most 
efficient for entering a sub-program routine from a 
main program and later returning to the main pro¬ 
gram. 

The terms “main program” and "sub-program” 
are purely relative. For example, in calculating the 
function c where 

“i = V- r i + V- r 2 + V- r 3 + • • • + V- r i 

it is seen that the square root of a number must be 
computed i times. It would be wasteful of storage 
space to write a program that consisted of f separate 
square-root programs. The obvious thing to do is to 
use the same square root program for every x. So the 
main program can be thought of as the one that cal¬ 
culates z t by using a square-root sub-program. 

Xow if we define a function Z such that 

-I ~2 -:!••• ~n_l 

then the main program can be thought of as the one 
that calculates Z n by means of a sub-program that 
calculates c,-; and finally the program for s t again uses 
the square-root program as a sub-program. Thus am- 
given program may be thought of as a sub-program 
in relation to a more extensive program, while it may 
be considered a main program in relation to a pro¬ 
gram it uses repeatedly. 

\\ ith these definitions, assume that two programs 
A and B are given, w-here A is the main program and 
B is a sub-program of A. Also suppose that program 
B is to be executed after instruction a — 1 of pro¬ 
gram A has been executed, and the execution of 
program A is to be continued after the execution of 
program B. Let the instruction stored in cell b be the 
first instruction of program B. Suppose that program 
B requires no information other than the address of 
the instruction to be executed after its completion. 
To provide information to compute this address, two 
instructions are stored at locations a and a + 1. 

(7—1 

(7 R ADD a \ 

a 4 - 1 TR b } Part of basic linkage 

fl + 2 


The instruction in cell a + 2 is to be executed aft er 
the completion of program B. Instruction a places 
the numerical representation of r add a in the accu. 
mulator. The next instruction transfers control to b 
which is the first instruction in program B. 


b 

b+ 1 

ADD 

STORE A 

L{ 2)\ 
b+k jf 

Part of basic linkage 



■ l 

Execution of the 



r 

• J 
[ J 

sub-program 

b + k 

TR 



Instruction b adds 2 to the contents of the accumula¬ 
tor which consequently contains the numerical repre¬ 
sentation of +r add a+2. Instruction b+\ stores 
n+2 into the address part of instruction b+k. The 
sub-program is then executed and finally comes to its 
last instruction, b+k ; this transfers control back to 
(7 + 2 of program A. The transfer into and out of the 
sub-program has now been completed. If program B 
was written to calculate the function sin .r. for exam¬ 
ple. it naturally must assume that ,r is located in some 
predetermined cell, say +1021. So a main program 
must place any pertinent information in locations 
where the sub-program can find it. This is done in the 
main program before transferring to the sub-program. 
Thus, program A must place the desired argument in 
a place where program B can find it. namely cell 
+ 1021. This, of course, must be done before the 
actual basic linkage is executed. 

Xote in the above technique that instructions b and 
h+1 could have been placed between instructions a 
and <7+1. However, this would require writing two 
additional instructions in program A for each time it 
is desired to execute program B. This could result in 
a considerable amount of extra storage space for in¬ 
structions if the sub-program is called on at quite a 
few different points in the main program. 

Occasionally, some of the information program B 
requires is not computed. For example, information 
may be specified by the programmer, such as the 
number of times program B is to be repeated, or the 
address of a quantity to be used by program B. Let Tit 
be a half-word of such information. The w can be 
stored in program A in the cell a + 2. 

(7—1 

a r add 

(7+1 TR 

(7 + 2 

(7 + 3 
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Instruction a + 3 is to be executed after the comple¬ 
tion of program B. For program B to use the quantity 
w it must be supplied with the location of w. Suppose 
instruction b + j, of program B, refers to w —that is, 
the address part of instruction b + j is to be a + 2, 
the location of w. The first four instructions of pro¬ 
gram B now become 


b 

ADD 

L(2) 

b+ 1 

STORE A 

b + j 

b + 2 

ADD 

L( 1) 

b + 3 

STORE A 

b + k 


Instructions b and b + 1 compute a + 2 and store the 
quantity as the address part of instruction b + j. In¬ 
structions b + 2 and b + 3 compute a + 3 and store 
that quantity as the address part of the last instruc¬ 
tion of program B. This last instruction to be exe¬ 
cuted in program B is again a transfer instruction 
that returns control to program A. Any amount of 
information could be supplied in a similar manner. 

All of the linkages described above result in an 
unconditional transfer to program B after the execu¬ 
tion of instruction a + 1 of program A. Conditional 
transfer is readily obtained by using the mq register 
to retain the address a. The following program shows 
the transfer to program B only if the accumulator 
contents are zero. 


<7—1 



<7 

LOAD MQ 

a 

<7 + 1 

TR 0 

b 

<7 + 2 



b 

L LEFT 

35 

6 + 1 

ADD 

L(2) 

b + 2 

STORE A 

b H” k 

b -f- k 

TR 

|> + 2 ; 


Branches and Forks 

The execution of the conditional transfer instruc¬ 
tion 


will be followed by execution either of the instruction 
>n cell b or the instruction in cell <7+1. Instruction b 
"'ill be executed if the accumulator is positive, and 


instruction <7+1 will be executed if the accumulator 
is negative. Thus the conditional transfer operation 
provides the possibility of executing either the in¬ 
structions in cells b, b + 1, b + 2 ... or the instruc¬ 
tions in cells <7 + 1, <7 + 2, <7 + 3, . . . , the choice 
based on the condition of the accumulator. The se¬ 
quence of instructions in cells b, b + 1, b + 2 . . . is 
called a branch, as is the sequence of instructions in 
cells <x + 1, a + 2, . .. . Each branch of a program is 
ordinarily a different computational procedure. For 
example, the instructions in cells a, a + 1, a + 2. . . . 
might be designed to evaluate y = sin x for win the in¬ 
terval 0 to -/2, and the other branch, the instructions 
in cells b, b + 1, b + 2,..., might be designed to 
evaluate the same function for x in the interval n/2 
to tt. The conditional transfer instruction could be 
used to select the appropriate branch for any argu¬ 
ment x in the interval 0 to v. That part of a program 
which provides the possibility of executing one of 
several branches is called a fork. A conditional trans¬ 
fer instruction is a fork. However, a fork mav be 
more than one instruction. Consider the pair of in¬ 
structions 


This pair of instructions is a three-branch fork. 
The instruction in cell b will be executed if the num¬ 
ber in the accumulator is zero. Instruction c will be 
executed if the contents of the accumulator are posi¬ 
tive and not zero. Instruction <7 + 2 will be executed 
if the accumulator contents are negative and not zero. 
If c is set equal to b. then the branch of instructions 
starting at cell b will be executed if the number in the 
accumulator is positive or zero. Bv appropriately 
specifying the address parts of this pair of instruc¬ 
tions, any of the conditions equal to, greater than, 
less than, greater than or equal to. or less than or 
equal to may be obtained. 

In the preceding example the choice of the branch 
to be executed is determined by the condition of the 
accumulator. The following four-branch fork shows 
that this is not always the case. Let b, c, d, and e be 
the addresses of the first instruction of four branches. 
Suppose the criterion for the branch selection is a 
parameter A which may take on the values 0, 1.2, 
and 3. For A = 0 the instruction in cell b is to be exe¬ 
cuted ; for A = 1, instruction c is to be executed; and 
so on. The selection can be done by computing the 
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address part of an unconditional transfer instruction 
as follows: 


a 

R ADD 

L{ A) 

fl+ 1 

ADD 

L(a + 4) 

a + 2 

STORE A 

(7+3 

o A 3 

TR 

[o + 4 + A] 

a + 4 

TR 

b 

a 4-5 

TR 

c 

a 4-6 

TR 

d 

o + 7 

TR 

e 

The address part 

of instruction a + 3 is computed by 

instructions a, a 

+ 1 and a 

+ 2. Instruction u + 3 

provides the selection of instruction a + 4 + A which 
is an unconditional transfer to the appropriate in- 

struction b, c, d or e. 


Occasionally it is convenient not to store the first 
three instructions of this fork adjacent to the uncon- 

ditional transfer 

instructions, but rather to separate 

the sets of instructions: 


a 

R ADD 

L(A) 

a + I 

ADD 

L((7 + k + 1) 

a + 2 

STORE A 

(7 + k 

o + k 

TR 

[(7 + k+ 1 + A] 

a + k+l 

TR 

b 

o + k + 2 

TR 

C 

o + k + 3 

TR 

d 

o + k 4—1- 

TR 

c 

Calculations may then be performed after the selec¬ 
tion of the branch but before executing the selected 
branch. This fork is then called a preset fork. 

Alternators 



The purpose of an alternator is to supply a pro- 

gram with two 

exits that 

alternate each time the 

program is executed. The following program illus¬ 
trates a method for doing this. In this program let x 
be a number that is positive the first time instruction 

a + 1 is executed. 


a 

o + 1 

R SUB 

L{x) 

o + 2 

STORE 

L(x) 

a+2 

TR + 

b 

(7 + 4 

TR 

c 


Instructions a + 1 and a + 2 result in the sign of x 
being changed in storage. The contents of the accu¬ 
mulator are negative; this results (by « + 3 and 
a + 4) in a transfer to the instruction located in 
cell c. Now, if program a + 1 is again reached during 
the problem, x is a negative number. The expressions 
a + 1 and a + 2 change x to a positive number and 
leave the accumulator positive. Instruction a + 3 then 
results in a transfer to the instruction in cell b. 
Further returns to a . + 1 will result in repetition of 
the two cycles mentioned above. In this way the pro¬ 
gram alternates between two branches of instructions. 

BINARY INPUT 

Programs that transmit binary information into elec¬ 
trostatic storage are presented in the following sec¬ 
tions. These programs were chosen because they: 

1. Illustrate many programming techniques. 

2. Are relatively simple. 

3. Are useful programs that may be used directly 
by many installations. 

4. Have been completely checked out on a 701 
installation. 

These programs do not necessarily represent the 
most efficient method of programming and, in addi¬ 
tion. programs may be written that are specifically 
adapted to the problems of a particular installation. 

Self-Loading Technique 

Often it is necessary to load a program into elec¬ 
trostatic storage without using any information al¬ 
ready contained in the electrostatic memory. This 
happens when the power has been turned off or when 
one programmer does not know, or does not care to 
know, what a previous programmer has left in elec¬ 
trostatic storage. For these occasions programs can 
be designed that are capable of loading themselves 
into the machine. The underlying principle of all such 
programs is the following. One instruction, which is 
onlv one half-word, can cause a full word to be placed 
in electrostatic storage. This full word may be com¬ 
posed of two instructions, each of which can put a 
full word into electrostatic storage. Thus, the two in¬ 
structions can store four more instructions in storage- 
In this way a surplus of instructions is rapidly built 
up; this may constitute a program capable of loading 
any desired number of half-words into electrostati c 
storage. 
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Two examples of self-loading programs are given 
below. Both programs are assumed to be punched in 
cards. The first program, which consists of only six 
instructions, will load itself and an additional 42 half¬ 
words (or 21 full words) punched in the same card. 
The six instructions that produce the self-loading 
feature are punched in the first three half-rows of the 
card. The last 21 half-rows of the card contain the 
program which it is desired to load. The six self- 
loading instructions are : 


+0000 

— COPY 

0002 

+0001 

+ R ADD 

0003 

+0002 

+ ADD 

0000 

+0003 

— COPY 

[0004] 

+0004 

+ STORE A 

0003 

+0005 

+ TR 

0002 


Figure 22 schematically shows the half-rows where 
the respective instructions are punched. 

Loading of the program is initiated front the oper¬ 
ator's panel. First, set the load selector switch to 
cards, and set the address entry keys to zero. Then 
depress the load button; this automatically starts the 
loading of the program by causing the calculator to 
execute a read instruction (with the address of the 
card reader as its address part) followed by the in¬ 
struction "—COPY 0000," causing the word in the 
left half of the 9-row to be stored at location —0000 
in electrostatic storage. This word is composed of the 
first two instructions of the program (numbered 
+0000 and +0001, above). Instruction number 
+0000 is then executed and results in instructions 
+0002 and +0003 (the right half of the 9-row) 
being stored at —0002. 


The execution of instructions +0001 and 4-0002 
causes the sum of the contents of half-word locations 
+0000 and +0003 to be formed in the accumulator. 
By reference to the Operations section in Part I, the 
numerical code for the operation part of a COPY in¬ 
struction is found to be 31 or, in binary, 11111. 
Therefore, the contents of the accumulator are: 


S 

Q p 

1<->17 ! 18<- 

1 

—>33 

— 

00 

11111000000000100 | 0. 

. . . 0 

— 

00 

11111000000000010 ; 0. 

1 

. . . 0 

— 

01 

11110000000000110 ! 0. 

. . . 0 


as a result of the addition of the two copy instruc¬ 
tions. Thus, bit positions 6 to 17 of the accumulator 
contain 0006. Since a binary 1 has carried over into 
the P overflow position of the accumulator, the over¬ 
flow indicator will be turned on. 

Next, instruction +0003 is executed, causing in¬ 
structions — 0004 and +0005 to be stored in full- 
word location —0004. The execution of instruction 
4-0004 replaces bit positions 6 to 17 of half-word 
location +0003 with the contents of bit positions 6 to 
17 of the accumulator register. Thus, instruction 
+0003 is modified and now becomes “—COPY 
0006.” Control is then transferred back to instruction 
+ 0002 when instruction +0005 is executed. 

During the succeeding repetition of the loop, the 
first two half-words of the program to be loaded 
into electrostatic storage are copied from the right 
half of the S-row and entered in full-word location 
—0006. Instruction +0003 is modified and becomes 
"—COPY 0008." Instruction 4-0005 again transfers 
control back to instruction +0002. This sequence of 


Row 

No. 

Left Half-Rows 
(Columns 1 -36) 

Right Half-Rows \ 

(Columns 37-72) \ 

12 

1 

- 1 

1 

11 

i 

1 

0 


1 

1 

1 

| 

1 

2 

1 

1 

3 

1 

1 

4 

1 

1 

1 

5 

1 

-1 

1 

6 

1 

1 

1 

7 

1 

1 

8 . 

+ Store A 0003 1 4- TR 0002 

1 

1 

9 

— Copy 0002 | 4- R Add 0003 

-1- Add 0000 j — Copy 0004 


Figure 22 
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events continues until an end-of-record signal is re¬ 
ceived, indicating that there are no more half rows of 
the card to be copied. The end-of-record condition 
then causes the copy instruction not to be executed 
and transfers control to +0006, which is the first in¬ 
struction of the desired program. Thereafter the cal¬ 
culator continues with the execution of this program. 
Observe that when the instruction stored at +0006 is 
executed, the overflow indicator is on, since it was 
turned on the first time instruction +0002 was exe¬ 
cuted, and no tr ov instruction has been given since. 
The indicator must be turned off if overflow indica¬ 
tion is to be used later for conditional control of the 
program itself. 

The foregoing method may be used only to load 
programs comprising not more than 42 instructions. 
The following self-loading program may be used to 
load any number of instructions punched on any num¬ 
ber of cards, to within the capacity of electrostatic 


storage: 


+0000 

— COPY 

0002 

+0001 

— COPY 

0004 

+0002 

+ R ADD 

0005 

+0003 

+ ADD 

0000 

+0004 

+ STORE A 

0005 

+0005 

— COPY 

[0004] 

+0006 

+ TR 

0002 

+0007 

+ TR 

0010 

+0008 

+ READ 

2048 

+0009 

+ TR OV 

0005 


These instructions are punched in the first card in 
the locations shown in Figure 23. The rest of the first 


card, starting with the right half of the 7-row, con¬ 
tains the first 38 instructions of the program to be 
loaded. Later instructions are placed in additional 
cards. 

Loading of the program is initiated from the oper¬ 
ator's panel by the same procedure described above. 
The copy instruction, executed automatically when 
the load button is depressed, causes instructions 
+0000 and +0001 to be entered in full-word loca¬ 
tion —0000 of electrostatic storage. Execution of in¬ 
structions +0000 and +0001 results in instructions 
+0002 to +0005 being stored in full-word locations 
-0002, -0004. 

Execution of instructions +0002 and +0003 re¬ 
sults in the sum of the contents of half-word locations 
+0005 and +0000 being formed in the accumulator. 
Just as in the previous example, bit positions 6 to 17 
of the accumulator contain the number 0006 and, 
since a binary 1 has carried over into the P overflow 
position, the overflow indicator is turned on. On the 
execution of instruction +0004, the contents of bit 
positions 6 to 17 of half-word location +0005 are re¬ 
placed with the contents of bit positions 6 to 17 of the 
accumulator register. Thus, instruction +0005 is 
modified and becomes “—COPY 0006." 

Next, the copy instruction +0005 is executed, 
causing instructions +0006 and +0007 ( punched in 
the right half of the 8-row) to be entered into 
full-word location —0006. Execution of instruction 
+0006 transfers control back to instruction +0002. 
On the second repetition of the loop, instruction 
+0005 is modified and becomes “—COPY 0008.” 
Then when instruction +0005 is executed, instruc¬ 
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tion +0008 and +0009 (punched in the left half of 
the 7-row) are loaded into full-word location —0008. 
Again, instruction +0006 transfers control back to 
instruction +0002, and the loop is repeated. 

On the next repetition, instruction +0005 becomes 
COPT 0010,” and the right half of the 7-row 
(containing the first two instructions of the program 
whose presence in electrostatic storage is desired) is 
loaded into full-word location —0010. The loop con¬ 
tinues to be repeated until all the half-rows of the 
first card have been copied and an end-of-record 
signal is received. Then, when the copy instruction 
+0005 is given, it is not executed; instead, control is 
transferred to instruction +0008. 

W hen the read instruction in +0008 is executed, 
another card feeds in the card reader. Since the over¬ 
flow indicator was turned on the first time instruction 
—0003 was executed and has not been turned off 
by a tr ov instruction, it is still on when instruction 
—0009 is given. Consequently, when instruction 
—0009 is executed, control is transferred back to the 
copy instruction (i-0005) whose execution was pre¬ 
viously prevented by the end-of-record condition. 
This copy is now executed, and the left half of the 
9-row of the second card is loaded into electrostatic 
storage. 


The loop consisting of instructions +0002 to 
+0006 is repeated until all 24 half-rows of the second 
card have been loaded. Then the end-of-record con¬ 
dition again causes control to be transferred to the 
read instruction, and the next card is fed. This se¬ 
quence of events continues until all cards have been 
read. Then the last read instruction, followed by the 
copy instruction +0005, sets up an end-of-file condi¬ 
tion. The copy instruction is not executed, and con¬ 
trol is transferred to instruction +0007; this in turn 
transfers control to the first instruction of the desired 
program that was stored in +0010. The calculator 
proceeds with the execution of this program. Note 
that the overflow indicator is off at the time instruc¬ 
tion +0010 is executed, since it was turned off by 
instruction +0009. 

Thus the desired program is loaded, as punched, 
into consecutive electrostatic locations beginning with 
+ 0010. 
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Binary Reading Program, L 05 

A program will now be described that can load 
itself into storage and later load blocks of binary in¬ 
formation into any section of electrostatic storage. 

The self-loading techniques described above require 
that every program to be loaded carry its own self¬ 
loading sequence and that all loading be done using 
the consecutively-numbered electrostatic storage loca¬ 
tions immediately following the locations occupied by 
the self-loading sequence itself. It is evident that these 
restrictions need not apply in general, since a self¬ 
loading sequence of six instructions may be used to 
enter a more general loading program. The following 
program (L 05) is an example of such a general 
program. 

L 05 is contained in a single card which also in¬ 
cludes six instructions that allow it to be entered by 
means of the load button. It makes use of electrostatic 
storage locations 0000 through 0047. L 05 may be 
used to enter binary information from any number of 
punched cards. This information may be stored in any 
desired consecutively-numbered electrostatic-storage 
locations, except those already reserved for L 05. 
Further, the reading and storing operations are 
checked by use of a check sum. 

A block of information to be loaded by L 05 must 
be preceded by a check sum, half-word count, and an 
initial loading address. These and other quantities 
will now be defined. 

Card Check Sum: This is calculated bv summing- 
the absolute values of all half-words in the block, in¬ 
cluding the half-words that specify the half-word 
count and initial loading address. The check sum 
itself is specifically excepted. To this sum is added 
2 1 ' times the number of negative half-words. The 
sum is then doubled, and a minus sign is attached. 
This card-check sum requires a binary full word and 
is punched in the left half of the 9-row of the first 
card in the group containing the block of information' 
to be loaded. 

Half-ll ord Count (V): This is the number of half¬ 
words to be loaded into consecutively-numbered loca¬ 
tions. This count does not include the four half-words 
that make up the card-check sum, the half-word 
count, and the initial loading address. This count re¬ 
quires a binary half-word and is punched in the sign 
position and positions 1-17 of the right half of the 
9-row of the first card. 
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Initial Loading Address (R): This specifies the 
locations into which the following block of informa¬ 
tion is to be loaded. The V half-words of the block 
are then loaded into electrostatic storage locations 
R + 2 through R + V + 1. Locations R and R + 1 
are reserved for the storage check sum (see below). 
R must be a positive even integer. It requires a binary 
half-word and is punched in positions 18-35 of the 
right word of the 9-row of the first card. 

Storage Check Sum: This is calculated by adding 
the quantity 2(V + R) to the card-check sum. The 
card-check sum is thereby reduced in absolute value. 

The following things should be noted about these 
quantities: 

1. Both V and R are included in the calculation of 
the check sum contained in the card. 

2. Since L 05 occupies electrostatic storage loca¬ 
tions 0000 through 0047, R must be greater 
than or equal to 0048. 


3. If more than one block of information is to b e 
loaded, then the following two requirements 
must be observed: 

a. The V half-words of each block must be 
loaded into consecutively numbered electro- 
static-storage locations, and 

b. Each block must start on a new card whose 
9-row contains the card check sum, the half¬ 
word count, and the initial loading address 
for that block. 

4. If V is odd. location R + V + 2 is set to zero. 

The output of the program consists of V + 2 half¬ 
words for each block of information entered. These 
half-words are stored in locations R through R + 
V + 1, the first two of these half-word locations 
being reserved for a full-word storage check sum 
computed from the card check sum by the program 
itself. 

Instructions for L 05 follow. This program is in 
turn followed by a general description of its operation. 


LOCATION 

INSTRUCTION 

± 

Operation Part 

Address Part 


0000 

— 

COPY 

31 

[0002] 


—*0001 


R ADD 

10 

[0003] 


0002 

[ 

ADD 

09 

0000] 

r- 

—0003 

— 

COPY 

31 

[0004] 

i 

i 

0004 


STORE A 

13 

0003 

l 

—0005 


TR 

01 

0001 

00M0006 


READ 

24 

2048 

1 

—0007 

— 

COPY 

31 

0002 

1 

1 —0008 


TR 

01 

0010 


-■>0009 


STOP 

00 

0001 


U 0010 

— 

COPY 

31 

0004 


0011 


R ADD 

10 

0005 


0012 


STORE A 

13 

0022 


0013 


STORE A 

13 

0028 


0014 


ADD 

09 

0045 


0015 


STORE A 

13 

0033 


0016 


ADD 

09 

0004 


0017 


STORE A 

13 

0001 


0018 


SUB 

05 

0045 


0019 


STORE A 

13 

0000 


0020 


A RIGHT 

23 

17 


0021 

— 

ADD 

09 

0002 


0022 

— 

STORE 

12 

[ ] 


0023 

— 

STORE 

12 

0002 


REMARKS 


Load L 05 card 


Select card reader 
Card check sum 
Not end of file 
End of file stop 
Loading information 

Obtain loading address for stor¬ 
age check sum and for copy 
sequence 

Reset address to initial value 

Set up end of copy index and 
end of add index 


Modify card check sum to give 
storage check sum 
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PROGRAMMING 


PROGRAM (continued) 



—>0024 

R ADD 

10 

0028 

’ 



0025 ! 

SUB 

05 

0045 




0026 

STORE A 

13 

0028 




0027 

SUB 

05 

0000 


- Copy sequence 



—0028 - 

COPY 

31 

[ ] 





—0029 

TR + 

03 

0024 




1 

l 

—0030 

TR 

01 

0033 




i__ 

->0031 i 

READ 

24 

2048 

Select card reader 



—0032 

TR 

01 

0028 

Continue copying 

0045 

^0033 

R ADD 

10 

[ ] 




0034 

STORE 

12 

0047 




0035 

R ADD 

10 

0033 




0036 

ADD 

09 

0009 




0037 

STORE A 

13 

0033 




0038 

SUB 

05 

0001 


- Add sequence 


0039 - 

LOAD MQ 

15 

0046 




0040 

L LEFT 

20 

36 




0041 - 

ADD 

09 

0002 




0042 - 

STORE 

12 

0002 



1 0033 

<—0043 

TR OV 

02 

0033 

J 


0006 

<—0044 

TR O 

04 

0006 

Test unit record sum j 


0045 

STOP 

00 

0002 

Error stop 


0046 

STOP 

00 

0000 

1 

Contribution to unit record sum | 


0047 [ 

STOP 

00 

0000] 

J 



A detailed description of each individual instruction 
of the above program is not included, but a general 
discussion of the operation of the program follows. 

Put the card containing L 05 at the front of the 
file of cards containing one or more blocks of binary 
information to be loaded. Place this file of cards in 
the card reader, restore the address entry keys to zero, 
and depress the load button. The rest of the loading 
operation takes place automatically under calculator 
control. 

The first six instructions of L 05 load the remain¬ 
der of this program. Control is then transferred to 
location 0006 as a result of the end-of-record skip. 
Instructions 0006, 0007 and 0010 read and copy the 
9-row of the first card whose information is to be 
entered into electrostatic storage. This row contains 
the card check sum and the quantities V and R. These 
Words are stored in locations —0002, +0004, and 
+■0005 and replace four instructions of the loading 
sequence, which is no longer required. The card check 
s nm, V, and R are then used by instructions 0011 
through 0023 to reset various address parts and to 
calculate the storage check sum stored both in loca¬ 
tions —R and —0002. 


The remaining V half-words of the block are then 
read and stored by instructions 0024 through 0032. 
When this information has been entered, control is 
transferred to location 0033. Instruction 0033 is the 
first of the loop, 0033 through 0043; this verifies that 
the newly-entered information is stored correctly. 
This verification is performed by the addition of 
successive half-words, whose signs are treated as de¬ 
scribed above, to the storage check sum stored in 
location 0002. 

After the I' half-words have been added to the 
storage check sum, instruction 0044 tests this new 
sum for zero. If no error has been made, this test for 
zero is successful, and control is transferred to loca¬ 
tion 0006. The calculator is now ready to read a sec¬ 
ond block of information. This process continues as 
long as no error is made and cards remain to be read. 

After the reading of the last group of cards whose 
binary contents are to be stored, the program verifies 
the correctness of the newly-entered information and 
again transfers control to location 0006. At this point, 
however, no cards remain to be read. So the end-of- 
file skip transfers control to location 0009, which con¬ 
tains a stop instruction. This signals the successful 
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completion of the loading operation. Should an error 
be detected in the summing of a block, the calculator 
stops at instruction 0045. 

L 05, once loaded, may be used any desired number 
of times without reloading simply by placing the cards 
to be read in the card reader and starting the calcu¬ 
lator at instruction 0006. 


CHECKING 

The validity of a problem solution involves several 
distinct aspects. Initial data must be correct. Usually 
input data are not susceptible to machine analysis for 
verification and must be guaranteed by the problem 
sponsor. Of course, transcribing the data onto cards 
may be verified by standard machine methods. The 
programming of the problem must be shown to rep¬ 
resent the actual sequence of operations required for 
the solution. The introduction of the data and pro¬ 
gram into the machine, the performance of the ma¬ 
chine during the solution, and the recording of the 
results should be verified. In all these checking opera¬ 
tions, the problem sponsor and programmer should 
determine the extent of the checking. The design of 
the 701 allows a large variety of methods for check¬ 
ing its operation and, as well, provides the pro¬ 
grammer with a wide choice of the extent of the 
checking. 

To ascertain the correctness of the program, expe¬ 
rience has shown that the program should be executed 
by the machine in a test cycle, and the results com¬ 
pared with expected results. One method is to inter¬ 
rupt instruction executions manually and examine 
the effects of the executions through the indicators 
on the operator s panel. Specific devices have been in¬ 
corporated to facilitate this technique of program 
verification and the correction of errors. Lights and 
buttons on the operator's panel provided for this pur¬ 
pose are the register lights, half-step key, multiple 
step key, memory display button, instruction entrv 
keys, mq entry keys, enter instruction button, and 
enter mq button. 

An alternative method (called ‘“tracing") has been 
used successfully on a 701 installation. In this method, 
the machine prints a record of the contents of the 
accumulator register, multiplier-quotient register, and 
the status of the overflow indicator for each instruc¬ 
tion-execution of the problem program; the machine 


also prints the instruction itself. We can examine th e 
resultant recording at leisure without consumin 
machine time. The special program for this is usually 
termed a tracing program. 

Error-detection mechanisms have been included i n 
the machine; these suspend calculation and signal an 
error when, because of programming errors, a copy 
or divide instruction is interpreted under circum¬ 
stances which, if executed, always would produce an 
erroneous result. These mechanisms include the copy 
check light and the divide check light. Checks for the 
introduction and recording of information are print 
echo pulses, double-punch blank-column detection 
and the tape check light. 

Because there is the possibility of the machine itself 
making an error, the performance of the machine 
during the solution of a problem must be checked. 
Such checks are usually embodied in the problem 
itself and should be regarded as part of the general 
procedure of efficient programming. The method of 
checking a particular problem is determined by the i 
character of the problem and the degree of confidence 
in the results the programmer desires. Thus, some 
problems have an inherent mathematical check in 
their solution, and for some a mathematical check can I 
easily be designed. A calculation can be checked by | 
duplicating it and comparing the two sets of results. j 
Another check is by duplicate calculation using com¬ 
plements of the original numbers, or bv duplicate 
calculation performed in the residue-class ring- of in- 

o 

tegers modulo some number />. 
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Consider programming of checking from the view¬ 
point of efficient operation. If a transient error should 
be made by the machine it is an advantage for the 
machine to repeat the calculation automatically; be¬ 
cause in the time required for the operator to reach 
the operator s control panel, the machine could have 
pei formed many operations. This is normally ar¬ 
ranged for by dividing the problem into parts, at nat¬ 
ural mathematical breaking points. The programming 
is so arranged that calculation, check calculation and 
comparison of results are done for one part and, if the 
results are correct, calculation of the next part is 
started. If, on the other hand, an error is detected, 
the calculation for that part is repeated. 

This section points out some techniques for check¬ 
ing solutions and input-output operations. There are 
many possibilities, and individual problems merit 
individual consideration. 
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Certain checking procedures have been continu¬ 
ously inserted in the preceding text. The previous 
section, Binary Reading Program L 05, showed how 
proper operation of the program is assured according 
to a predetermined card check sum. An example of a 
mathematically designed check is a square-root pro¬ 
gram checked by squaring the result and comparing 
it with the original argument. This is not necessarily 
the best method for checking a square-root program 


in a particular problem, but it does show one of the 
possibilities for this kind of check. 

It cannot be emphasized too strongly how impor¬ 
tant it is to include appropriate checks in a program. 
The extent and method of checking is entirely de¬ 
pendent upon the degree of confidence in the results, 
which is determined by the problem's importance and 
the needs of the problem sponsor. 
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EXAMPLES 


This section gives several examples of program¬ 
ming that progressively use more and different oper¬ 
ations and so become lengthier and more complicated. 
These examples can be studied in sequence to under¬ 
stand how different operations work together to 
create a meaningful program. We have already re¬ 
ferred to some of these examples in the Operations 
section of Part I. Input-output operations are not 


illustrated here because they have been covered under 
Input-Output Components. 

Some of the examples cover such operations as 
forming a rounded 35-bit quotient, transferring con¬ 
trol on non-zero, transferring control on minus, 
vector addition, and square root. Most of the exam¬ 
ples use programming conventions described in the 
earlier Programming section. 


1. The following program will: add a 35-bit number A found in electrostatic 
location —1492 to a 35-bit number B located at —15S8; double the sum ; and 
store the result in location —1812. Assume that the result does not carry over 
into the overflow positions of the accumulator. 


LOCATION 

INSTRUCTION 

REMARKS 

± 

Operation Part 

Address Part 

1066 

— 

R ADD 

10 

1492 

Place A in the accumulator 

1067 

— 

ADD 

09 

1588 

Form A-\-B 

1068 


A LEFT 

22 

1 

Form 2(A-\-B) by shifting one 






binary place left 

1069 

— 

STORE 

12 

1812 

Place 2(A-{-B)mES location-1812 
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2. Two sets of programming are given; either one may be used to compute 
A-B. 


T OP A TTOTVT 

INSTRUCTION 


± 

Operation Part 

Address Part 

1066 

— 

R ADD 

10 

L(A) 

1067 

. - 

SUB 

05 

L(B) 

1068 

— 

STORE 

12 

X 


If A — B, the result of computing A — B is zero with the sign of A. 


INSTRUCTION 


REMARKS 

Place A in accumulator 
Place —B in accumulator forming 
A-B 

Place result in location x 


LOCATION 


Operation Part 

Address Part 

REMARKS 

1066 

— 

R SUB 

06 

L(B) 

Place — B in accumulator 

1067 

— 

ADD 

09 

L(A) 

Form — B+A 

1068 

— 

STORE 

12 

X 

Place result in location x 


ms as 
g c - 


exam- 

in 


If A - B in this programming, the result of computing —B + A is zero with 


the sign of — B. 


3. Suppose C + |Nj — \B\ is to be calculated with the result stored in x. 
Also assume that an overflow into position P might occur: in this case the sum 
should be rounded to 35 bits before it is stored in x. 


T nr A TTOXT 


INSTRUCTION 


LULa I lUJiN 

± 

Operation Part 

Address Part 

REMARKS 

1066 

— 

r add 

10 

L(C) 

Place +C in accumulator 

1067 

— 

ADD AB 

11 

L(A) 

Form +C+ A | 

1068 

— 

SUB AB 

07 

L(B) 

Form -f C+ A\ — \B\ 

1069 


TR OV 

02 

1071 

Transfer to rounding procedure if 
overflow occurred 

1070 


TR 

01 

1073 

Transfer to storing procedure if 
overflow did not occur 

1071 

1072 


L RIGHT 

ROUND 

21 

19 

1 

Shift sum right one place 

Round 

1073 

— 

STORE 

12 

X 

Place sum in location x 


' ' 
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The long right-shift instruction causes the combined contents of the accumu¬ 
lator and mq registers to shift one place to the right. Thus, the bit in the right¬ 
most overflow position enters the first position of the accumulator register; 
the bit in the 35th position of the accumulator enters the first position of the 
mq register. Since the store instruction only reads out the accumulator register, 
the bit remaining in the mq register after rounding is dropped. 


4. To truncate without rounding and without disturbing the contents of the 
mq register, the a right and a left operations may be used. Assume in this 
program that the least significant 5 bits of the sum A + B are to be dropped. 



INSTRUCTION 


J-<UL/A JL 

± 

Operation Part 

Address Part 

REMARKS 

1066 

— 

R ADD 10 

L(A) 

Place A in accumulator 

1067 

— 

ADD 09 

L(B) 

Forms A+B 

1068 


A RIGHT 23 

5 

The 5 least significant bits of 





A-\rB are shifted out of the reg- 





ister and lost 

1069 


A LEFT 22 

5 

The number is returned to its 





original position with the 5 low 





order digits now zero 

1070 

— 

STORE 12 

x 

Places the truncated sum in Ioca- 





tion x 


5. Multiplication of B by A to form a 35-bit rounded product can be done as 
follows: 




INSTRUCTION 


JL X iNi 

± 

Operation I 

"’ART 

Address Part 

REMARKS 

1066 

— 

LOAD MQ 

15 

L(A) 

Place A in the mq register 

1067 

— 

MPY R 

17 

L(B) 

Form AB and round 

1068 


STORE 

12 

X 

Place rounded product in loca¬ 
tion .r 


The multiply-round instruction forms the 70-bit product AB and rounds the 
product to 35 bits. The rounded product is then stored from the accumulator. 
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6. To shift the product before rounding, use the following procedure: 


( 


LOCATION 

INSTRUCTION 

REMARKS 

± 

Operation Part 

Address Part 

1066 

— 

LOAD MQ 

15 

L(A) 

Place A in the mq register 

1067 

— 

MPY 

16 

L(B) 

Form AB 

1068 


L LEFT 

20 

3 

Shift AB three places left 

1069 


ROUND 

19 


Round 

1070 

— 

STORE 

12 

X 

Place rounded answer in location x 


The long left-shift instruction causes the combined contents of the accumulator 
and mq registers to be shifted left three places. After rounding, the contents of 
the accumulator register are stored. 


7. Suppose that A j < |B < 1 and that it is desired to find the 35-bit 
rounded quotient of A b_4 B. The following programming will accomplish this 
result. 


t nr* a TTn\ T 

INSTRUCTION 

REMARKS 

1 lU/iN 

it 

Operation Part 

Address Part 

1066 - 

R ADD 

10 

L(B> 

Place B in the accumulator 

1067 

L RIGHT 

21 

36 

Place 2~ 36 B (with respect to the 





entire dividend) in the mq reg- 





ister 

1068 ' - 

R ADD 

10 

L(A! 

Form A+2~ 36 B 

1069 ■ - 

DIV 

18 

L(B ) 

Form rounded quotient 

1070 i — 

STORE MQ 

14 

X 

Place rounded quotient in loca- 

I 




tion x 


The accumulator and mq registers together serve as a 70-bit dividend register 
during division. The dividend A + B is formed by shifting B into the mo 
register from the accumulator register and then placing A in the accumulator 
register. During division the sign of the entire 70-bit dividend is taken to be the 
sign of the accumulator register (i.e., the sign of A) ; the sign of the mo register 
is ignored. Thus, in effect, the dividend has the modulus (absolute value) 

Ml + 2- 3B \B\ 

and the sign of A. So the quotient on division by B has the modulus 

Ml i 9-30 

Ml + “ 

and the sign of A/B. Consequently, after division the mq register contains the 
quotient A/B rounded to 35 bits. 
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8. A shifted and rounded quotient may be obtained as follows. Assume that 
the half-word location +0055 contains the number zero; also that the quotient 
is to be shifted four places to the right and then rounded. 


LOCATION 

INSTRUCTION 

REMARKS 

± 

Operation Part 

Address Part 

1066 


LOAD MQ 

15 

0055 

Reset mq register to zero 

1067 

— 

R ADD 

10 

L(A) 

Place A in the accumulator register 

1068 

— 

DIV 

18 

L(B) 

Form A/B 

1069 


R ADD 

10 

0055 

Clear remainder from accumula- 






tor register 

1070 


L LEFT 

20 

31 

Shift quotient into accumulator 






register 

1071 


ROUND 

19 


Round shifted quotient 

1072 


A LEFT 

22 

4 

Returns number to proper relative 






location in register 

1073 

— 

STORE 

12 

X 

Store rounded, truncated quotient 






in x 


The load mq instruction resets the mq register to zero. Note that to reset all 
35 bits of the mq register, it is not necessary to have a 35-bit zero in storage, 
because when a half-word is loaded into the mq register the 18 rightmost bits 
automatically become zero. A similar remark applies to the clearing of the 
remainder from the accumulator after division. The 31 leftmost bits of the 
quotient are shifted into the accumulator register, leaving the four rightmost 
bits in the mq register. The truncated (31-bit) quotient is then rounded. Instruc¬ 
tion 1072 then shifts the quotient to its proper relative location in the register, 
and finally the store instruction writes the rounded 31-bit quotient from the 
accumulator register in full-word location x. The four bits left in the mq register 
are dropped. 

9. Transfers on non-zero and minus can be effected by these two devices: 


LOCATION 


INSTRUCTION 

REMARKS 

dr 

Operation Part 

Address Part 

1066 


TR O 

04 

1068 

Transfer to 1068 if accumulator 
contains zero 

1067 


TR 

01 

X 

Hence, transfer to .r if accumula¬ 
tor is non-zero 


LOCATION 


INSTRUCTION 

REMARKS 

± 

Operation Part 

Address Part 

1066 


TR + 

03 

1068 

Transfer to 1068 if accumulator is 
plus 

1067 


TR 

01 

X 

Hence, transfer to .r if accumula¬ 
tor is minus 


Other more complicated discriminations are also possible. 
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10. The transfer operations can be used to make the machine choose among 
several programs. The following example is almost identical to a program ex¬ 
plained above under Programming, except that no symbolism will be used here. 

Assume there are four possible programs whose initial instructions are located 
in electrostatic storage: 

Program Address of Initial Instruction 

I +0051 

n +0351 

HI +0651 

IV . +0951 

Also assume that the decision as to which of the four programs to be used has 
already been made in the course of the problem and that the result of this decision 
is indicated by the presence of one of the four numbers 1, 2, 3, 4 in the accumu¬ 
lator register. Suppose further that the number 1068 is stored at location +1812 
in electrostatic storage. The following set of instructions will direct the machine 
to choose the appropriate one of the four programs: 


LOCATION 


INSTRUCTION 

j -1_ 

1 ^ 

Operation Part 

1 Address Part 


ADD 

09 

1812 


STORE A 

13 

1068 


TR 

01 

[ 1068+k] 


TR 

01 

0051 


TR 

01 

0351 


TR 

01 

0651 

1 

TR 

01 I 

0951 


REMARKS 

Compute 1068+&, where k = 1, 
2. 3, or 4 

Address part of instruction at 
+ 1068 becomes 1068+& 
Program transferred to +1069, 
+ 1070, +1071, or +1072 
Transfer to Program I 
Transfer to Program II 
Transfer to Program III 
Transfer to Program IV 


11. As an example of the use of the arithmetic and logical instructions, a 
square-root program will now be presented. The program is intended only for 
illustration and does not necessarily represent the most efficient method of 
obtaining square root. The argument A, whose square root is desired, is assumed 
to he rn the range 0 < A < 1 — 2~ 35 and to be stored at location —1588. The 
square root is computed by the well-known iteration formula 

Assume that the first approximation is the number 

y 0 = 1 — 2“ 35 

| stored at the full-word location —1492 in electrostatic storage; the final result 
is to be stored at —1812. Also the contents of half-word location +0055 are 
assumed to be zero. 
















TYPE 701 AND ASSOCIATED EQUIPMENT 

Note th 

( (a) 

-0504, 

(b) 

respecti 

( c ) 

i.e.j %i - 

(d) 

(e) 

= +2C 

(f) 
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The first two instructions of the program set up the calculation by placing _v 0 in 
location —1812. These two instructions are used only once. The succeeding 
instructions compute the new approximation y n from the old approximation 
y„_i and test for convergence. As soon as y„ — y„_i = 0 to 34 binary places, 
the iteration stops. The transfer-on-zero instruction causes the rest of the itera¬ 
tion to be skipped and the next instruction to be taken from location +1080; 
this location may contain the initial instruction of a program for terminating the 
calculation. For instance, if A is sufficiently far from zero so that one more cycle 
of iteration will give the accuracy desired, the termination program might per¬ 
form an additional cycle carried to extra precision and then round the result to 
the desired number of places. 

12. Another sample program, showing the technique of computing addresses, 
is the following program for adding two n-dimensional vectors. Assume that a 
vector 

X = (>!, X'2 -- X n ) 

is to be added to a vector 

Y = (Vi. y-j, ■ ■ ■ , ?„) 

, •+) = (- r i + Vi. - r 2 + y-2’ ■ 


INSTRUCTION 


LOCATION 

± Operation Part 

Address Part 

REMARKS 

1066 

— R ADD 

10 

1492 

Place Vo in the accumulator 

1067 

— STORE 

12 

1812 

Store y 0 in —1812 

1068 

LOAD MQ 

15 

0055 

Reset mq register to zero 

1069 

— R ADD 

10 

1588 

Place A in the accumulator 

1070 

— DIV 

18 

1812 

Compute A/y n _i 

1071 

A RIGHT ' 

23 

37 

Reset accumulator to zero 

1072 

L LEFT 

20 

35 

Put A/y n _i in accumulator 

1073 

— ! SUB 

i 

05 

1812 

Compute — — y n -i 
_V„-1 

1074 

L RIGHT 

21 

2 

Compute 4 [”y B — y n _i”| = I ~ Tn-i 

1075 

TR 0 

04 

1080 

Transfer to end if y n = y n -\ to 34 
places 

1076 

i L LEFT 

20 

1 

Compute v„ — v„_i = $ — v„_ 

Ly„_i J 

1077 

1 

— j ADD 

09 

1812 

Compute y„ = v„_ i + i ~~ 

1078 

— j STORE 

12 

1812 

Store y„ in —1812 

1079 

TR 

01 

1068 

Repeat cycle of iteration 

1080 

i 



Start termination procedure 


to form the vector 
Z = (*. 


• •, -i'» + y „) - A’ + Y 


The fi 
the th 
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Note the following: 

( (a) Components of X are stored in consecutive full-word locations —0502, 

-0504, . . . , -(0500 + 2m). 

(b) Components of Y are stored in —1002, —1004,... , —(1000 4- 2 m), 
respectively. 

(c) The calculation assumes that Z is to replace X in electrostatic storage— 
i.e., s t = Xi + y\ replaces x t in —(0500 + 2i), for f = 1,2,..., n. 

(d) The half word “—add (1000 + 2m + 2)” is stored at location +2000. 

(e) The constant 500 is stored at location +2001. In other words, L ( + 500) 

= + 2001 . 

(f) The constant 2 is stored at location +2002. In other words, L (2) = 
- 2002 . 

(g) The symbol /, is used to represent the half word “—add (1000 + 2/).” 
Thus, 

/f_i stands for “—add (1000 + 21 + 2)” 

I n - 1 stands for “—add (1000 + 2m + 2)“ 

Tite program: 


i 

INSTRUCTION 



LOCATION 





REMARKS 

± 

Operation 

-’art 

Address Part 



1500 


R SUB 

! 06 

2001 



1501 


SUB 

05 

i 7 002 


Resets addresses of operating 

1502 


STORE A 

13 

1506 


1503 


STORE A 

13 

1508 


instructions to proper start- 

1504 


SUB 

05 

2001 


ing values 

1505 


STORE A 

13 

1507 



1506 

1507 

1508 

— 

R ADD 

ADD 

STORE 

10 

09 

12 

[0500+ 2i] 
[1000 + 2i] 
[0500+ 2i) 


Operating instructions which 
calculate and store z t = .ty + j' ; 

1509 


R ADD 

10 

1506 



1510 


SUB 

05 

2002 


These instructions modify the 

1511 


STORE A 

13 

1506 


1512 


STORE A 

13 

1508 


addresses of the operating in- 

1513 


R ADD 

10 

1507 


structions in preparation for 

1514 


SUB 

05 

2002 


calculating s i+1 

1515 


STORE 

12 

1507 



1516 


SUB 

05 

2000 

1 

A comparison test to see if the 

1517 


TR + 

03 

1506 

J 

last component of Z has been 
calculated 


The first six instructions of the program (located at +1500 to +1505) restore 
the three operating instructions ( + 1506, +1507, +1508) to their initial status 








(* — !)• Thus, after the execution of instruction +1505, the operating instruc¬ 
tions read: 


1506 

— R ADD 

0502 

1507 

— ADD 

1002 

1508 

— STORE 

0502 


So no matter what the addresses of the operating instructions originally were, 
they are reset to their proper starting values. 

The working part of the program consists of the three operating instructions 
located at +1506 to +1508. These instructions add the ;th component of Y and 
store the sum (i.e., the ith component'of Z) at —(0500 + 2i). The succeeding 
seven instructions (located at +1509 to +1515) serve to modify the three oper¬ 
ating instructions by adding 2 to the magnitude of each address part. 

The two instructions located at +1516 and +1517 test whether all n compo¬ 
nents of the two given vectors have been added. If i < n, then since 

i + l 7 n + 1 > 0, 

the tr + instruction transfers control back to instruction +1506 and .r i+1 
is added to a , £ _ 1 to form r i+1 . If i = n, then since I i+1 — I n _ 1 = —0, the tr + 
instruction does not transfer control and the next instruction is taken from 
+1518. Xote that I n +i (stored at +2000) is actually a constant of the program, 
although it has the form of an instruction. By modifying this constant, the 
program can be altered to accommodate vectors of varying dimension. 





APPENDIX 


APPEN 

BINARY AND OCTAL 

In the familiar decimal system of representing 
numbers, a number is expressed by a sum of terms. 
Each individual term consists of a product of a power 

of ten and some integer in the set 0. 1.9. For 

example. 

123 = (l X 10'*) + (2 X 10') -h (3 X 10"). 

28.875 = (2 X 10') + (8 X 10") 4- (8 X 10~') 

+ (7 X 10- 2 ) + (5 X 10- 3 ). 

Ten is said to be the base of this system because of the 
role that the powers of ten and the integers up to ten 
play in the above expansions. 

If two is chosen as the base, numbers are said to be 
represented in the binary system. For example, the 
decimal number 

123 = 64 + 32 + 16 + 8 + 2 + 1 

= (1 X 2") + (1 X 2 s ) + (1 X 2 4 ) 

+ (!X2 S ) + (0X2 S ) + (IX 2') 

+ (1 X 2"). 

If only the coefficients of the powers of two arc 
written, the binary representation of 123 becomes 
1111011. This is exactly how the form of a decimal 
number is created. Because the binary representation 
of a number requires only the two digits 0 and 1. the 
binary system lends itself naturally to the use of elec¬ 
trostatic storage, magnetic drums and tapes, trigger 
circuits, etc. These devices can be used to greater ad¬ 
vantage and efficiency with the binary system than 
with the decimal. 

It will be observed that the number systems used in 
this appendix are subject to the familiar commutative, 
distributive, and associative laws of arithmetic. 

Although binary numbers in general have more 
terms than their decimal counterparts (on an average, 
about 3.3 times as many), computation in the binary 
system is quite simple. The rules for adding binary 
digits are 

0 + 0 = 0 

1+0=1 

1 + 1 = 10 (0 with 1 carried) 


DIX A 

NUMBER SYSTEMS 

For example. 1111011 may be added to itself as 
follows: 

carries: 1111 11 

1111011 
+ 1111011 
11110110 

The rules for subtracting binary digits are equally 
simple: 

0-0 = 0 
1 - 1=0 
1 - 0=1 

0—1 = 1 (with 1 borrowed) 

For example. 1111011 may be subtracted from 
11110110 as follows: 
borrows: 1111 11 
11110110 
- 1111011 
1111011 

The multiplication table for binary digits is given by 
0X0 = 0 
1X0 = 0 
1X1 = 1 

The rules for carrying out multiplication and division 
in longhand are entirely similar to those used with 
the decimal system. For example, the multiplication 
of 111 by 101 is done as follows: 

111 

101 

lTT 

000 

111 

100011 

The problem of converting a number represented in 
decimal to the same number as represented in binary 
is quite simple. 

The binary representation of an integer can be ob¬ 
tained from its decimal representation through calcu¬ 
lations carried out in either the decimal or binary . 
system. Calculations in the decimal system will be ^ 
discussed in this case since it is of most interest. The 


method consists of successive divisions by two as 
follows: 

1 Consider the number 123. which may lie repre¬ 
sented as 

123 = 2 X 61 — 1 = 2 ( 32+ 16 + 8 + 4+1)+1 
Thus, dividing 123 by 2 gives the quotient 61 and 
remainder 1; this remainder is the coefficient of 2" in 
the binary representation of 123. The coefficient of 2' 
in the binary representation of 123 is equal to the 
remainder obtained on dividing 61 (the previous quo¬ 
tient ) by 2. 

61 = 2 X 30 + 1 = 2 (16 + 8 + 4 + 2) + 1 
Similarly. 30 gives the remainder zero on division by 
2. corresponding to the fact that the coefficient of 2 2 
is 0 in the binary representation of 123. The complete 
calculation for the conversion of 123 to the binary 
notation is: 

123 -5- 2 = 61 + remainder of 1 

61 -f- 2 = 30 + remainder of 1 

30 *5- 2 = 15 + remainder of 0 

15 -s- 2 = 7 + remainder of 1 

7 -r 2 = 3 + remainder of 1 

3 -j- 2 = 1 + remainder of 1 

1 - 5 - 2 = 0 + remainder of 1 

( The highest power of 2 appearing in the binary rep¬ 
resentation of 123 is 2" and the coefficient of 2" is the 
quotient 1 obtained in the last step above. The binary 
representation of 123 therefore consists of seven 
binary digits and is obtained by writing down, in 
succession from right to left, the above six remainders 
in the order in which they were calculated. Thus. 

(123)io = (1111011). 

Conversely, to convert a binary integer to decimal 
form through calculation in the binary system, simply 
divide successively by ten until a quotient of zero is 
obtained. The remainders, expressed in decimal nota¬ 
tion and written in succession from right to left, give 
the desired decimal representation. The procedure is 
very similar to the procedure carried out in the deci¬ 
mal system for converting (1111011). = (123)t» 
and is as follows: 

1111011 -r 1010 = 1100 + remainder of 11 

1100 -r- 1010 = 1 + remainder of 10 

1 -j- 1010 = 0 + remainder of 1 

The decimal representation then consists of the inte¬ 

gers 1. 10. and 11 in that order from left to right. 
When converted to decimal, these binary integers give 
1. 2. and 3. respectively. Consequently the decimal 
representation of 1111011 is 123. 


The binary representation nf a proper decimal frac¬ 
tion may be generated digit by digit through succes¬ 
sive multiplication by two in the decimal system. The 
procedure is somewhat like the integer conversion 
procedure described above. 

For example, consider the decimal fraction .625. 
In order to illustrate the technique it will be assumed 
that the answer is already known. Thus. 

.625 = (1 X 2-' | + (0 X 2~ s ) + 1 X 2- 3 

= 0.101 (in binary | 

A multiplication by two gives 
1.25 = 1.01 (in binary) 

The integral parts of each number are equal to one 
and thus represent the first binary bit to the right of 
the point. Now. using the fractional parts of the two 
numbers above, we have by a multiplication of two 
2 X .25 = 0.5 
10 X .01 =0.1 (in binary) 

The integral parts of the result are equal to zero; 
this is the second binary bit to the right of the point. 
Similarly, the third binary bit is calculated by 
2 X .5 = 1.0 
10 X .1 = 1.0 


and the third binary bit to the right of the point is 
seen to be 1. 

Of course, further multiplications with the remain¬ 
ing fractional parts would result in zeros. So the con¬ 
version is complete, and 

.625 = .101 (in binary) 

Not all terminating decimal fractions, however, 
can be represented as terminating binary fractions. 
The following calculations follow the pattern as out¬ 
lined above for converting 0.35 to binary. A position 


It an x indicates 
ermined. 

that this position has not yet been 

Calculation 

0.35 

Binary Representation 
O.xx.xxxxxxxxxxxx... 

X 0.35 

= 

0.7 

O.Oxxxxxxxxxxxxx... 

X .7 

= 

1.4 

O.Olxxxxxxxxxxxx... 

X .4 

= 

0.8 

O.OlOxxxxxxxxxxx... 

X .8 

= 

1.6 

0.01 Olxxxxxxxxxx ... 

X .6 

= 

1.2 

0.0101 Ixx.x.xxxxxx ... 

X .2 

= 

0.4 

0.010110.xxxxxx.xx ... 

X .4 

= 

0.8 

0.0101 lOOx.xxxxxx ... 

X .8 

= 

1.6 

0.0101 lOOlxxxxxx ... 

X .6 

= 

1.2 

0.01011001 Ixxxxx ... 

X .2 

= 

0.4 

0.01011001 lOxxxx... 

X .4 

= 

0.8 

0.01011001 lOOxxx... 
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It is evident that this procedure will repeat indefi¬ 
nitely. Thus, the terminating decimal fraction 0.35 
equals the non-terminating recurring binary fraction. 
An approximate representation of 0.35 as a terminat¬ 
ing binary fraction may be obtained by rounding. For 
instance, rounding to eight binary places may be done 
by adding one-half in the eighth place, which in the 
binary system is equivalent to adding 1 in the ninth 
place, as follows: 

0.01011001J10011001100... 

!l 

0 . 0101101000011001100 ... 

The approximate eight-place binary representation of 
0.35 is therefore 

0.01011010 

Improper decimal fractions may be converted to 
binary by converting the integral and fractional parts 
separately or by scaling the number so that it becomes 
an integer or a proper fraction. For example. 

(28.875),,, = (11100.111), 

Or, to convert the decimal number 15.625, first write 
•t as a proper fraction times a scale factor: 

15.625 = 0.15625 X 10 2 
Then, converting each factor separately gives 

(15.625), 0 = (0.00101), X (1100100), 

= ( 1111 . 101 ), 

If the base 8 is chosen for representing numbers, 
the representation is said to be in the octal system. 
For example, 

(123) ,0 = 1X8 ! + 7X8 , -|-3X8 0 = (173) s 


The dccimal-to-octal conversion of an integer can be 
effected by dividing successively by 8 (in the decimal 
system) until a quotient of zero is obtained. The octal 
representation then consists of the successive remain¬ 
ders written in order front right to left. 

Octal-to-binarv conversion is particularly simple. 
Because 8 equals 2 3 . the conversion is carried out 
merely by replacing the octal digits with their 
binary equivalents expressed as three-digit binary 
numbers. For example, to convert the octal number 
173. simply replace 3 with 011. 7 with 111. and 1 
with 001. and obtain 1111011. omitting the zeros on 
the extreme left. Conversely, to pass from binary to 
octal, simply arrange the binary digits in groups of 
three, beginning at the binary point and proceeding to 
the left and to the right. Fill out with zeros at the 
extreme right or left if necessary. Then replace each 
group of three binary digits with its octal equivalent. 
For example. 

( 11100 . 111 ), = ( 011 . 100.111 ) 3 = ( 34 . 7 )* 
Thus, the octal notation furnishes a convenient short¬ 
hand for the binary notation, especially for handling 
large numbers. The integer whose binary representa¬ 
tion consists of thirty-five l’s is the largest integer 
that can be represented by thirty-five binary digits. In 
decimal notation this integer, which equals 2“ — 1, 
requires eleven digits: 

34.359.738.367 

Its octal representation requires twelve digits: 
377.777.777.777 

Hence, in this case the octal system is only a little less 
economical of notation than the decimal system but is 
considerably more economical than the binary system. 
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APPENDIX B 


TABLE 

OF POWERS OF 2 

2 " 

1 

0 

2~ m 

1.0 

2 

1 

0.5 

4 

2 

0.25 

8 

3 

0.125 . 

16 

4 

0.062 5 

32 

5 

0.031 25 

64 

6 

0.015 625 

128 

7 

0.007 812 5 

256 

8 

0.003 906 25 

512 

9 

0.001 953 125 

1 024 

10 

0.000 976 562 5 

2 048 

11 

0.000 488 281 25 

4 096 

12 

0.000 244 140 625 

8 192 

13 

0.000 122 070 312 5 

16 384 

14 

0.000 061 035 156 25 

32 768 

15 

0.000 030 517 578 125 

65 536 

16 

0.000 015 258 789 062 5 

131 072 

17 

0.000 007 629 394 531 25 

262 144 

18 

0.000 003 814 697 265 625 

524 288 

19 

0.000 001 907 348 632 812 5 

1 048 576 

20 

0.000 000 953 674 316 406 25 

2 097 152 

21 

0.000 000 476 837 158 203 125 

4 194 304 

22 

0.000 000 238 418 579 101 562 5 

8 388 608 

23 

0.000 000 119 209 289 550 781 25 

16 777 216 

24 

0.000 000 059 604 644 775 390 625 

33 554 432 

25 

0.000 000 029 802 322 387 695 312 5 

67 108 864 

26 

0.000 000 014 901 161 193 847 656 25 

134 217 728 

27 

0.000 000 007 450 580 596 923 828 125 

268 435 456 

28 

0.000 000 003 725 290 298 461 914 062 5 

536 870 912 

29 

0.000 000 001 862 645 149 230 957 031 25 

1 073 741 824 

30 

0.000 000 000 931 322 574 615 478 515 625 

2 147 483 648 

31 

0.000 000 000 465 661 287 307 739 257 812 5 

4 294 967 296 

32 

0.000 000 000 232 830 643 653 869 628 906 25 

8 589 934 592 

33 

0.000 000 000 116 415 321 826 934 814 453 125 

17 179 869 184 

34 

0.000 000 000 058 207 660 913 467 407 226 562 5 

34 359 738 368 

35 

0.000 000 000 029 103 830 456 733 703 613 281 25 

68 719 476 736 

36 

0.000 000 000 014 551 915 228 366 851 806 640 625 

137 438 953 472 

37 

0.000 000 000 007 275 957 614 183 425 903 320 312 5 

274 877 906 944 

38 

0.000 000 000 003 637 978 807 091 712 951 660 156 25 

549 755 813 888 

39 

0.000 000 000 001 818 989 403 545 856 475 830 078 125 
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APPENDIX C. OCTAL-DECIMAL .INTEGER CONVERSION TABLE 


OCTAL-DECIMAL INTEGER CONVERSION TABLE 


0000 0000 

0777 0511 

(Octol) (Decimal) 


1000 0512 

1777 1023 

(Octal) (Decimal) 


3 


10000 10000 0001 0002 0003 000-1 0005 0006 

10010 10008 0009 0010 0011 0012 0013 001-1 

10020 10016 0017 0018 0019 0020 0021 0022 

( 0030 >0024 0025 0026 0027 0028 0029 0030 

j 00-10 10032 0033 003-1 0035 0036 0037 0038 

i 0050 .’00-10 0041 0042 0043 0044 0045 0046 

1006010048 0049 0050 0051 0052 0053 0054 
0070 0056 0057 0058 0059 0060 0061 0062 


10100 0064 0065 0066 0067 0068 0069 0070 0071 

j 0110.0072 0073 0074 0075 0076 0077 0078 0079 

0120 10080 0081 0082 0083 0084 0085 0086 0087 

, 013010088 0089 0090 0091 0092 0093 0094 0095 

10140 0096 0097 0098 0099 0100 0101 0102 0103 

015010104 0105 0106 0107 0108 0109 0110 0111 
0160 10112 0113 0114 0115 0116 0117 0118 0119 

0170 0120 0121 0122 0123 0124 0125 0126 0127] 


10200 
•0210 
; 0220 
! 0230 


024010160 
1025010168 
0260 10176 
0270 | 0184 


0129 0130 0131 
0137 0138 0139 
0145 0146 0147 
0153 0154 0155 
0161 0162 0163 
0169 0170 0171 
0177 0178 0179 
0185 0186 0187 


.0300 

0310 

0320 

i0330 

10340 

10350, 

0360: 

03701 


0193 0194 
0201 0202 
0209 0210 
0217 0218 
0225 0226 
0233 0234 
0241 0242 
0249 0250 


0133 0134 0135 
0141 0142 0143 
0149 0150 0151 
0157 0158 0159 
0165 0166 0167 
0173 0174 0175 
0181 0182 0183 
0189 0190 0191 

0197 0198 0199 
0205 0206 0207 
0213 0214 0215 : 
0221 0222 0223, 
0229 0230 0231 i 
0237 0238 0239! 
0245 0246 0247! 
0253 0254 0255 | 


0 1 2 3 4 5 6 7 


j 040010256 0257 0258 0259 0260 0261 0262 0263, 

0410'0264 0265 0266 0267 0268 0269 0270 0271 

042010272 0273 0274 0275 0276 0277 0273 0279 

0430:0280 0281 0282 0283 0284 0285 0286 0297; 

0440 |0288 0289 0290 0291 0292 0293 0294 0295 

0450:0296 0297 0298 0299 0300 0301 0302 0303- 

0460(0304 0305 0306 0307 0308 0309 0310 0311 : 

0470; 0312 0313 0314 0315 0316 0317 0318 0319! 

0500 10320 0321 0322 0323 0324 0325 0326 0327 i 
(0510 0328 0329 0330 0331 0332 0333 0334 0335 
i 0520 0336 0337 0338 0339 0340 0341 0342 0343! 
0530'0344 0345 0346 0347 0348 0349 0350 0351 : 

0540 0352 0353 0354 0355 0356 0357 0358 0359! 

10550-0360 0361 0362 0363 0364 0365 0366 0367: 

' 0560 j 0368 0369 0370 0371 0372 0373 0374 0375 I 
0570 j 0376 0377 0378 0379 0380 0381 0382 0383’ 

j 0600 : 0384 0385 0386 0387 0388 0389 0390 0391 
'0610} 0392 0393 0394 0395 0396 0397 0393 0399 1 
j 062010400 0401 0402 0403 0404 0405 0406 0407 

10630'0408 0409 0410 0411 0412 0413 0414 0415 

0640 0416 0417 0418 0419 0420 0421 0422 0423 

'065010424 0425 0426 0427 0428 0429 0430 0431 

0660 0432 0433 0434 0435 0436 0437 0438 0439 ( 

|0670,0440 0441 0442 0443 0444 0445 0446 0447 1 

10700 0448 0449 0450 0451 0452 0453 0454 0455, 

071010456 0457 0458 0459 0460 0461 0462 0463* 

j 0720 j 0464 0465 0466 0467 0468 0469 0470 0471 1 
0730 0472 0473 0474 0475 0476 0477 0478 0479 ! 

1074010480 0481 0482 0483 0484 0485 0486 0487 ; 

| 0750 j 0488 0489 0490 0491 0492 0493 0494 0495 j 
0760 j 0496 0497 0498 0499 0500 0501 0502 0503 
1077010504 0505 0506 0507 0508 0509 0510 05111 



1400 

0768 

0769 

0770 

0771 

0772 

0773 

0774 

0775 

141C 

0771 

0771 

077! 

077! 

078( 

078: 



I42C 

078-1 

0785 

0786 

078 - 

0731 

078! 

0791 


I43C 

0792 

0791 

079-1 

0795 

0796 

079" 

0791 

0799 

1443 

080C 

0801 

0802 

080: 

080. 

0805 

0801 


1450 

0808 

0809 

081C 

081] 

0812 

08i: 


0815 

1460 

0816 

0813 

08 IS 

081! 

082C 

0821 

0822 

0823 

1470 

0824 

0825 

0826 

0827 

0828 

0829 

0830 

0831 

1500 

0832 

0833 

0834 

0835 

0836 

0837 

0838 

0839 

1510 

084C 

0841 

0842 

0843 

0844 

0845 

0846 

0847 

1520 

0848 

0849 

0850 

0851 

0852 

0853 



1530 

0856 

0857 

0858 

0859 

0860 

0361 

0862 


1S40 

0864 

0865 

0866 

0867 

0868 

0869 

0870 


1550 

0872 

0873 

0874 

0875 

0876 

0877 



1560 

0880 

0881 

0882 

0883 

0884 

0885 



1570 

0888 

0889 

0890 

0891 

0892 

0893 

0894 

0895 

1600 

0896 

0897 

0898 

0899 

0900 




1610 

0904 

0905 

0906 

0907 

0908 

0909 



1620 

0912 

0913 

0914 

0915 

0916 

0917 

0918 

0919 


0920 

0921 

0922 

0923 

0924 

0925 




D928 

0929 

0930 

3931 

0932 

0933 



1650 

0936 

0933 

0938 

3939 

0940 

3941 

0942 

3943 


3944 

0945 

0946 

39 47 

0948 




1670 

0952 

0953 

0954 

0955 

0956 

0957 

0958 

0959 

1700 

0960 

0961 

0962 

0963 

0964 

0965 



1710 

3968 

3969 

3970 

3971 

39 72 

3973 




3976 

3977 

3978 

3979 

3980 

3981 

39 8 2 

3983 



3985 

39 8 6 

398 7 

3988 

3989 



1740 

3992 

3993 

3994 

3995 

3996 

3997 

3998 



1000 

1001 

1002 

1003 

1004 

1005 



1760 

1008 

1009 

1010 

1011 

1012 

,013 




1016 

1017 

1018 

1019 

1020 

1021 

1022 

1023 


( 


< 



1537 1538 1539 
1545 1546 1547 
1553 1554 1555 
1S61 1562 1563 
1569 1570 1571 
1577 1578 1579 
1585 1586 1587 
1593 1594 1595 


1540 1541 
1548 1549 
1556 1557 
1564 1565 
1572 1573 
1580 1581 
1588 1589 
1596 1597 


1542 1543 
1550 1551 
1558 15591 
1566 1567 
1574 1575 
1582 1583 
1590 1591 
1598 15991 


1600 1601 1602 1603 1604 1605 1606 1607 
1608 1609 1610 1611 1612 1613 1614 1615 
1616 1617 1618 1619 1620 1621 1622 1623| 
1624 1625 1626 1627 1628 1629 1630 1631 
1632 1633 1634 1635 1636 1637 1838 1639 
1640 1641 1642 1643 1644 1645 1646 1647, 
1648 1649 1650 1651 1652 1653 1654 1655 
1656 1657 1658 1659 1660 1661 1662 1663 


1669 1670 1671 
1677 1678 16791 
1685 1686 1687 
1693 1694 1695 
1701 1702 1703 
1709 1710 1711 
1717 1718 1719 
1725 1726 1727 


1730 1731 
1738 1739 
1746 1747 
1754 1755 
1762 1763 
1770 1771 
1778 1779 
1786 1787 


1733 1734 1735, 
1741 1742 17431 
1749 1750 1751 
1757 1758 17591 
1765 1766 1787 
1773 1774 1775 
1781 1782 17831 
1789 1790 1791 


1792 1793 
1800 1801 
1808 1809 
1816 1817 
1824 1825 
1832 1833 
1840 1841 
1848 1849 


1794 1795 1796 
1802 1803 1804 
1810 1811 1812 
1818 1819 1820 
1826 1827 1828 
1834 1835 1836 
1842 1843 1844 
1850 1851 1852 


1797 1798 17991 
1805 1806 1807' 
1813 1814 1815 
1821 1822 1823 
1829 1830 1831 
1837 1838 1839| 
1845 1846 1847 
1853 1854 1855 


1856 1857 
1864 1865 
1872 1873 
1880 1881 
1888 1889 
1896 1897 
1904 1905 
1912 1913 


1858 1859 1860 
1866 1867 1868 
1874 1875 1876 
1882 1883 1884 
1890 1891 1892 
1898 1899 1900 
1906 1907 1908 
1914 1915 1916 


1861 1862 1863 
1869 1870 1871 
1877 1878 1879 
1885 1886 1887 
1893 1894 1895 
1901 1902 1903 
1909 1910 19111 
1917 1918 19191 


1920 1921 1922 1923 1924 1925 1926 1927 
1928 1929 1930 1931 1932 1933 1934 1935 
1936 1937 1938 1939 1940 1941 1942 1943| 
1944 1945 1946 1947 1948 1949 1950 1951 
1952 1953 1954 1955 1956 1957 1958 1959 
1960 1961 1962 1963 1964 1965 1966 1967 
1968 1969 1970 1971 1972 1973 1974 1975 
1976 1977 1978 1979 1980 1981 1982 1983| 


1984 1985 
1992 1993 
2000 2001 
2008 2009 
2016 2017 
2024 2025 
2032 2033 
2040 2041 


1988 1989 
1996 1997 
2004 2005 
2012 2013 
2020 2021 
2028 2029 
2036 2037 
2044 2045 


1990 1991 
1998 1999 
2006 2007 
2014 2015 
2022 2023 
2030 2031 
2038 2039 
2046 2047! 


2000 | 1024 

to to 
2777 j 1535 
(Octal) i (Decimal) 


3000 1536 

3777 2047 

'Octal) (Decimal) 













OCTAL-DECIMAL INTEGER CONVERSION TABLE 


OCTAL-DECIMAL INTEGER CONVERSION TABLE 


4000! 2048 2049 2050 2051 2052 2053 2054 2055 
4010' 2056 2057 2058 2059 2060 2061 2062 2063 
4020 2064 2065 2066 2067 2068 2069 2070 2071 
4030i 2072 2073 2074 2075 2076 2077 2078 2079 
4040 ' 2080 2081 2082 2083 2084 2085 2086 2087 
4050‘ 2088 2089 2090 2091 2092 2093 2094 2095 
4060' 2896 2097 2098 2099 2100 2101 2102 2103 
4070' 2104 2105 2106 2107 2108 2109 2110 2111 

4100 2112 2113 2114 2115 2116 2117 2118 2119 
4110, 2120 2121 2122 2123 2124 2125 2126 2127 
4120; 2128 2129 2130 2131 2132 2133 2134 2135 
4130' 2136 2137 2138 2139 2140 2141 2142 2143 
4140 2144 2145 2146 2147 2148 2149 2150 2151 
4150 2152 2153 2154 2155 2156 2157 2158 2159 
4160 2160 2161 2162 2163 2164 2165 2166 2167 
4170 2168 2169 2170 2171 2172 2173 2174 2175 

42001 2176 2177 2178 2179 2180 2181 2182 2183 
4210; 2184 2185 2186 2187 2188 2189 2190 2191 
4220 2192 2193 2194 2195 2196 2197 2198 2199 
4230 2200 2201 2202 2203 2204 2205 2206 2207 
4240 2208 2209 2210 2211 2212 2213 2214 2215 
4250 2216 2217 2218 2219 2220 2221 2222 2223 
4260: 2224 2225 2226 2227 2228 2229 2230 2231 
42701 2232 2233 2234 2235 2236 2237 2238 2239 

4300'2240 2241 2242 2243 2244 2245 2246 2247! 
4310 2248 2249 2250 2251 2252 2253 2254 22551 
4320 2256 2257 2258 2259 2260 2261 2262 2263 
4330,2264 2265 2266 2267 2268 2269 2270 2271 i 
4340,2272 2273 2274 2275 2276 2277 2278 2279! 
435012280 2281 2282 2283 2284 2285 2286 2287! 
436012288 2289 2290 2291 2292 2293 2294 2295 
4370| 2296 2297 2298 2299 2300 2301 2302 2303| 


5000 2560 2561 2562 2563 2564 2565 2566 2567 
501012568 2569 2570 2571 2572 2573 2574 2575 
5020 2576 2577 2578 2579 2580 2581 2582 2583 
503012584 2585 2586 2587 2588 2589 2590 2591 
5040 2592 2593 2594 2595 2596 2597 2598 2599 
5050'2600 2601 2602 2603 2604 2605 2606 2607 
506012608 2609 2610 2611 2612 2613 2614 2615 
507012616 2617 2618 2619 2820 2621 2622 2623 

510012824 2625 2626 2627 2628 2629 2630 2631 
5110 2632 2633 2634 2635 2636 2637 2638 2639 
5120 2640 2641 2642 2643 2644 2645 2646 2647 
5130 2648 2649 2650 2651 2652 2653 2654 2655 
5140 2656 2657 2658 2659 2660 2661 2662 2663 
5150 2664 2665 2666 2667 2668 2669 2670 2671 
516012672 2673 2674 2675 2676 2677 2678 2879 
5170 ,'2680 2681 2682 2683 2684 2685 2686 2687 

5200 2688 2689 2690 2691 2692 2693 2694 2695 
5210 2698 2697 2698 2699 2700 2701 2702 2703 
5220 2704 2705 2706 2707 2708 2709 2710 2711 
5230 2712 2713 2714 2715 2716 2717 2718 2719 
5240 2720 2721 2722 2723 2724 2725 2726 2727 
5250 2728 2729 2730 2731 2732 2733 2734 2735 
5260 2736 2737 2738 2739 2740 2741 2742 2743 
5270 2744 2745 2746 2747 2748 2749 2750 2751 

5300 2752 2753 2754 2755 2756 2757 2758 2759 
5310 2780 2761 2782 2763 2764 2765 2766 2767 
5320 2768 2789 2770 2771 2772 2773 2774 2775 
5330 2776 2777 2778 2779 2780 2781 2782 2783 
5340 2784 2785 2786 2787 2788 2789 2790 2791 
5350 2792 2793 2794 2795 2796 2797 2798 2799 
5380 2800 2801 2802 2803 2804 2805 2806 2807 
5370 2808 2809 2810 2811 2812 2813 2814 2815 


2434 2435 2436 
2442 2443 2444 
2450 2451 2452 
2458 2459 2460 
2466 2467 2468 
2474 2475 2476 
2482 2483 2484 
2490 2491 2492 


8 2309 2310 2311, 
6 2317 2318 2319! 
4 2325 2326 23271 
2 2333 2334 2335; 
0 234 1 2342 23431 
8 2349 2350 2351 j 
6 2357 2358 2359! 

4 2365 2366 2367j 

2 2373 2374 237SI 

3 2381 2382 2383! 
i 2389 2390 2391 1 

5 2397 2398 2399 : 
1 2405 2406 2407 
s 2413 2414 2415 
) 2421 2422 2423' 
i 2429 2430 2431 

2437 2438 2439 > 
2445 2446 2447 > 
2453 2454 2455 
2461 2462 24631 
2469 2470 2471' 
2477 2478 2479 
2485 2486 2487; 
2493 2494 2495' 


4600 2432 2433 
4610 2440 2441 
4620 2448 2449 
4630 2456 2457 
4640 2464 2465 
4650 2472 2473 
4660 2480 2481 
4670 2488 2489 

4700 2496 2497 1 
4710 2504 2505 
4720 2512 2513 
4730 2520 2521 
4740 2528 2529 
4750 2536 2537 2 
4760 2544 2545 2 
4770 2552 2553 2 


540012816 2817 2818 2819 2820 2821 2822 2823! 
5410'2824 2825 2826 2827 2828 2829 2830 2831 1 
5420 2832 2833 2834 2835 2836 2837 2838 2839! 

5430 2840 2841 2842 2843 2844 2845 2846 2847 

5440 2848 2849 2850 2851 2852 2853 2854 2855 

5450 2856 2857 2858 2859 2860 2861 2862 2863 

5460 2864 2865 2866 2867 2868 2869 2870 2871 

5470 2872 2873 2874 2875 2876 2877 2878 2879 

5500 2880 2881 2882 2883 2884 2885 2886 2887 

5510 2888 2889 2890 2891 2892 2893 2894 2895 

5520 2896 2897 2898 2899 2900 2901 2902 2903 

5530 2904 2905 2906 2907 2908 2909 2910 2911 

5540 2912 2913 2914 2915 2916 2917 2918 2919 

5550 2920 2921 2922 2923 2924 2925 2926 2927 

5560 2928 2929 2930 2931 2932 2933 2934 2935 

5570 2936 2937 2938 2939 2940 2941 2942 2943 


> 2946 2947 2948 1 

1 2954 2955 2956 2 

l 2962 2963 2964 2 

> 2970 2971 2972 2 

r 2978 2979 2980 2 

i 2986 2987 2988 2 

I 2994 2995 2996 2 

1 3002 3003 3004 2 

I 3010 3011 3012 3 

’ 3018 3019 3020 3 

i 3026 3027 3028 3 

I 3034 3035 3036 3 

3042 3043 3044 3 

I 3050 3051 3052 3 

r 3058 3059 3060 3 

i 3066 3067 3068 3 


2949 2950 2951 | 
2957 2958 2959 ! 
2965 2966 2967 
2973 2974 2975 
2981 2982 2983 
2989 2990 2991 ! 
2997 2998 2999 I 
3005 3006 3007 



5 3137 3138 3139 3 
1 3145 3146 3147 3 
! 3153 3154 3155 3 
) 3161 3162 3163 3 
) 3169 3170 3171 3 
> 3177 3178 3179 3 
I 3185 3186 3187 3 
1 3193 3194 3195 3 

) 3201 3202 3203 3 
I 3209 3210 3211 3 
i 3217 321& 3219 3 
i 3225 3226 3227 3 
! 3233 3234 3235 3 
) 3241 3242 3243 3 
I 3249 3250 3251 3 
S 3257 3258 3259 3 

l 3265 3266 3267 3 
! 3273 3274 3275 3 
) 3281 3282 3283 3 
I 3289 3290 3291 3 
i 3297 3298 3299 3 
l 3305 3306 3307 3 
• 3313 3314 3315 3 
1 3321 3322 3323 3 


I 3205 3206 3207 
1 3213 3214 3215 
) 3221 3222 3223, 
3 3229 3230 32311 
> 3237 3238 3239| 
1 3245 3246 3247; 
! 3253 3254 3255 
) 3261 3262 3263! 

i 3269 3270 3271 
i 3277 3278 3279 
I 328S 3286 3287 
! 3293 3294 3295 
) 3301 3302 3303 
) 3309 3310 3311 
j 3317 3318 3319 
1 3325 3326 3327 


16400'3328 3329 3330 3331 : 
j 64101 3336 3337 3338 3339 : 
6420! 3344 3345 3346 3347 : 
j 6430j 3352 3353 3354 3355 1 
! 64401 3360 3361 3362 3363 ! 
*6450; 3368 3369 3370 3371 I 
;6460| 3376 3377 3378 3379 : 
164701 3384 3385 3386 3387 ! 


7000 3584 3585 3586 3587 3588 3589 3590 3591 
7010 3592 3593 3594 3595 3596 3597 3598 3599 
7020 3600 3601 3602 3603 3604 3605 3606 3607 
7030 3608 3609 3610 3611 3612 3613 3614 3615| 
7040 3618 3817 3618 3619 3620 3621 3622 36231 
7050 3624 3625 3626 3627 3628 3629 3630 3631 
7060 3632 3633 3634 3635 3636 3637 3638 3639 
7070 3640 3641 3642 3643 3644 3645 3646 3647 

7100 3648 3649 3850 3651 3652 3653 3654 3655 
7110 3656 3657 3658 3659 3660 3661 3662 3663 
7120 3664 3665 3666 3667 3668 3669 3670 3671 
7130 3672 3673 3674 3675 3676 3677 3678 3679 
7140 3680 3681 3682 3683 3684 3685 3686 3687 
7150 3688 3689 3690 3691 3692 3693 3694 3695 
7160 3696 3697 3698 3699 3700 3701 3702 3703 
7170 3704 3705 3706 3707 3708 3709 3710 3711 

7200 3712 3713 3714 3715 3716 3717 3718 3719 
7210 3720 3721 3722 3723 3724 3725 3726 3727 
7220 3728 3729 3730 3731 3732 3733 3734 3735 
7230 3736 3737 373B 3739 3740 3741 3742 3743 
7240 3744 374S 3746 3747 3748 3749 3750 3751 
7250 3752 3753 3754 3755 3756 3757 3758 3759 
7260 3760 3761 3762 3763 3764 3765 3766 3767 
7270 3768 3769 3770 3771 3772 3773 3774 3775 

7300 3776 3777 3778 3779 3780 3781 3782 3783 
7310 3784 3785 3788 3787 3788 3789 3790 3791 
7320 3792 3793 3794 3795 3796 3797 3798 3799 
7330 3800 3801 3802 3803 3804 3805 3806 3807 
7340 3808 3809 3810 3811 3812 3813 3814 3815. 
7350 3816 3817 3818 3819 3820 3821 3822 3823 
7360 3824 3825 3826 3827 3828 3829 3830 3831 
7370 3832 3833 3834 3835 3836 3837 3838 3839 


1 3333 3334 3335 
) 3341 3342 3343 
1 3349 3350 3351 
5 3357 3358 3359 

1 3365 3366 3367 

2 3373 3374 3375 
) 3381 3382 3383 

3 3389 3390 3391, 

5 3397 3398 3399 

1 3405 3406 3407 

2 3413 3414 3415 
) 3421 3422 3423 

3 3429 3430 3431 
3 3437 3438 3439 

1 3445 3446 3447 

2 3453 3454 3455 


66001 3456 3457 3458 3459 3460 3461 3462 3463, 

1661013484 3465 3466 3467 3468 3469 3470 3471, 

1662013472 3473 3474 3475 3476 3477 3478 3479, 

'6630(3480 3481 3482 3483 3484 3485 3486 3487' 

166401 3488 3489 3490 3491 3492 3493 3494 3495 1 

66501 3496 3497 3498 3499 3500 3501 3502 3503! 

6660| 3504 3505 3506 35C 7 3508 3509 3510 3511, 

667013512 3513 3514 3515 3516 3517 3518 35191 

670013520 3521 3522 3523 3524 352S 3526 3527 

671013528 3529 3530 3531 3532 3533 3534 3535 

6720 3536 3537 3538 3539 3540 3541 3542 3543 

6730 3544 3545 3546 3547 3548 3549 3550 3551! 

6740 3552 3553 3554 3555 3556 3557 3558 3559' 

6750 3560 3561 3562 3563 3564 3565 3566 35671 

6760 3568 3569 3570 3571 3572 3573 3574 35751 

6770 3576 3577 3578 3579 3580 3581 3582 35831 


7400 3840 3841 3842 3843 3844 3845 3846 3847 
7410 3848 3849 3850 3851 3852 3853 3854 3855 
7420 3856 3857 3858 3859 3860 3861 3862 3863 
7430 3864 3865 3866 3867 3868 3869 3870 3871 
7440 3872 3873 3874 3875 3876 3877 3878 3879 
7450 3880 3881 3882 3883 3884 3885 3886 38871 
7460 3888 3889 3890 3891 3892 3893 3894 3895 
7470 3896 3897 3898 3899 3900 3901 3902 3903 

7500 3904 3905 3906 3907 3908 3909 3910 3911 
7510 3912 3913 3914 3915 3916 3917 3918 3919 
7520 3920 3921 3922 3923 3924 3925 3926 3927 
7530 3928 3929 3930 3931 3932 3933 3934 3935 
7540 3936 3937 3938 3939 3940 3941 3942 3943 
7550 3944 3945 3946 3947 3948 3949 3950 3951 
7560 3952 3953 3954 3955 3956 3957 3958 3959 
7570 3960 3961 3962 3963 3964 3965 3966 3967 


7600 3968 3969 3970 3971 ! 
7610 3976 3977 3978 3979 : 
7620 3984 3985 3986 3987 i 
7630 3992 3993 3994 3995 : 
7640 4000 4001 4002 4003 4 
7650 4008 4009 4010 4011 4 
7660 4016 4017 4018 4019 4 
7670 4024 4025 4026 4027 4 


! 3973 3974 3975 
) 3981 3982 3983 
1 3989 3990 3991 
i 3997 3998 3999| 
I 4005 4006 4007 
! 4013 4014 40151 
) 4021 4022 4023 
) 4029 4030 4031 

i 4037 4038 4039 
I 404 5 4046 4047 
! 4053 4054 4055 
) 4061 4062 4063 
1 4069 4070 4071 
i 4077 4078 4079 
1 4085 4086 4087 
! 4093 4094 4095 
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APPENDIX D 


TIMING 

FIGURES 24. 25. and 26 arc simplified timing 
charts of the most commonly used features of the 
Type 721 Card Recorder. Type 711 Card Reader, 
and Type 716 Alphabetic Printer. These timing 
charts are included as a further aid whenever timing 
gives a better understanding of the feature to he con¬ 
trolled. 

Each machine cycle of the card reader, card re¬ 
corder. and alphabetic printer requires a certain 
number of milliseconds. During the machine' cycle, a 
series of operations related to reading a card, punch¬ 
ing a card, or printing a line of information is com¬ 
pleted. The total number of milliseconds required to 
complete a machine cycle is split into a number of 
units called cycle points. The number of cycle points 
per machine cycle varies according to the nature of 
the mechanical operations to be performed. 

The card recorder is a 14-cycle-point machine 
( Figure 24). The card recorder cycle is not divided 
into degrees, but rather into tenths of a cycle point. 

The machine cycle of the card reader is split into 
20 cycle points, as indicated in Figure 25. Because the 
| card reader cycle is further divided into 360°. each of 
the 20 cycle points is 18° of a card reader cycle. 

As shown in Figure 26. the alphabetic printer cycle 
is divided into 360°. Because the alphabetic printer is 
a 24-cycle-point machine, each cycle point is 15° of an 
alphabetic printer cycle. 

Each machine has an index, marked as shown in 
the charts. The index rotates in synchronism with 
mechanical units in the machines. The read, punch, or 
print cycle is considered as being started when the 
units associated with reading, punching or printing 
are set in motion. An asterisk in the chart indicates 
starting time in relation to the machine index. For the 
card reader, the time is 330°; for the can! recorder, 
it is 13.5 or D time; and. for the alphabetic printer, 
the time is 345°. 

Note that the card recorder index is marked off as 
though the cards are fed 12-edge first. It is necessary 
to convert 12 time to 9 time. 0 time to 7 time, and 
so on, when thioking of the position of a card row 
in relation to the machine index. 

( 


CHARTS 

Type 721 Card Recorder 

Cure/ Cycles. Each cycle that the feed mechanism 
is set in motion, a pulse is available at these hubs. 

Digit Impulse. These impulses are available each 
cycle that the feed mechanism is set in motion. 

Punch Brushes. Pulses of the duration shown are 
made available at the punch brush hubs while a card 
is being read at this station. 

Control Brushes. Control punches in the S-row of 
a card are sensed at 13.1 to 13.5 of a punch cycle. 

Selector Hold. Selectors are held transferred until 
9.5 of a punch cycle after being picked up by any 
punch brush pulse or digit impulse. An impulse from 
a control brush may also transfer a selector. This 
means that the selector points transfer at the end of a 
punch cycle and are held transferred until 9.5 of the 
succeeding punch cycle. 

Punch Delay Out. An impulse is available one 
punch cycle following the sensing of a control punch 
(punch control brush wired to punch control in). 

Column Split. The column split acts as an inter¬ 
nally wired selector that transfers from the 9-0 side 
to the 11-12 side after 0 impulse time (7.4 on the 
machine index). The contacts return to their normal 
positions at 13.4 time. 

Sense E.vits 1 and 2. The cam that controls the 
sense exits is made from 14.9 until 14.2 of the follow¬ 
ing feed cycle as shown in the chart. To be certain 
that a sense instruction having a punch address is 
effective, the sense instruction should be programmed 
immediately following the write (punch) instruction 
or sometime after the first copy instruction. 

Usually an impulse from a sense exit hub controls 
selectors. It is usually desirable to have the selectors 
transferred at the beginning of the punch cycle. In 
general, the sense instruction follows the write 
(punch) instruction. If so. the impulse available at 
the sense exit hub lasts until 14.2 of the punch cycle. 
By this time, the selector relays have established 
their hold circuits. 

Whenever selectors are to be energized during a 
cycle, remember that at least six milliseconds are 
required to transfer the selector points. 
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If a sense instruction is programmed after a write 
(punch) instruction and the punch is not ready, the 
pulse is available at the sense exit hub until 14.2 of 
the first calculator controlled punch cycle. 

Caution note: If a sense (punch) instruction is 
programmed after a copy instruction and the sense 
exit pulse is used to control a selector, the selector 
transfers for the remainder of the current cycle. Be¬ 
cause the sense exit pulse is available until 14.2 of 
the next punch cycle, the selector is held transferred 
an additional cycle. 

Type 711 Card Reader 

Card Cycles. Each cycle that the card feed mech¬ 
anism is set in motion, a 2° to 218° impulse is 
emitted from the card cycles hubs. 

Digit Impulses. Each cycle that a card is read 
under control of the calculator, the digit impulses are 
available at the digit impulse hubs. 

Control Brushes and Reading Brushes. Control 
brush and read brush pulses are available at these 
brush hubs as cards are read at the brush stations. 

Split Column Control. These pulses are available 
between the normal read impulse times during each 
( feed cycle. 

Pilot Selector. The pilot selector transfer relays 
may be energized by an 11 or 12 impulse or a digit 
impulse (9 through 12). The selector transfers at 
240° of the cycle. It remains transferred until 225° 
of the next card feed cycle. 

For immediate transfer of the pilot selector, the im¬ 
mediate hubs should be impulsed. These hubs are 
receptive from 280° of a card feed cycle until 230° of 
the following card feed cycle. 

Pilot Selector—Coupling Exit. Whenever an 11-12 
pu or 9-12 pu hub is used to energize a pilot selector 
control relay, a pulse is available at the corresponding 
coupling exit hub the following cycle from 340° until 
016°. The coupling exit impulse usually controls co¬ 
selectors. The transfer time of a co-selector can be 
from 252° of one card feed cycle until 225° of the 
following card feed cycle. 

Type 716 Alphabetic Printer 

Carriage Skip. Because skipping is an afterprint 
^ operation, the carriage skip hubs are not receptive 
until any before-print spacing operation has been ini¬ 


tiated. To be effective, an impulse to the carriage skip 
hubs must occur between 230 c and 310 9 of a print 
cycle. 

Space Suppress. An impulse directed into these 
hubs between 320 ; and 110° of a print cycle sup¬ 
presses before-printing spacing. 

Extra Space. An impulse directed into this hub 
after 5° and before 320° of a print cycle provides an 
extra-space-after-printing operation according to the 
printer control panel wiring. 

Overflow. An impulse is available from the over¬ 
flow hubs during the betore-print-space operation 
that precedes printing of the last line on the form. If 
the overflow operation is not delayed, the impulse 
lasts until 320° of the current print cycle. Otherwise 
the pulse is available until 320° of the print cycle 
during which the overflow operation starts. 

Short Skip. An impulse directed to a short skip 
hub before 300° of a print cycle during which a skip¬ 
ping operation is starting or taking place releases the 
interlock normally causing the printer to lose at least 
one machine cycle for each skipping operation. 

Son-Print. An impulse directed to this hub before 
110° of a print cycle prevents printing, spacing before 
printing, and ribbon spacing. 

Split Column Control Emitter. These hubs emit 
impulses between normal digit impulses, i.e., the 9 
hub emits an impulse between the normal 9 and 8 
times of the master cb pulses. 

Alterations. When the corresponding alteration 
switch on the switch panel is on. the alteration hub 
emits a 0° to 30° impulse each print cycle. 

Print Cycles. These hubs emit pulses during each 
print cycle from 355° to 285°. 

Co-Selector Pickup. A co-selector is held trans¬ 
ferred the remainder of a print cycle if it is pulsed 
sometime after 350 J . 

Pilot Selector. A pilot selector control relay can 
be energized any time between 5° and 310° of a 
print cycle. The [joints of the pilot selector relay are 
held transferred from 315° of a print cycle until 286° 
of the following print cycle. 

Coupling Exit. A pulse is available at a pilot se¬ 
lector coupling exit from 330° of the print cycle that 
a pilot selector control relay is energized until 195° 
of the following print cycle. 





PRINTWHEEL ECHO IMPULSES 
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Sense Entry. The sense entry hub is receptive at 
all times. 

Sense Exit. Usually the sense exit hubs are condi¬ 
tioned so that pulses can be emitted from these hubs 
between 240° and 350° of a print cycle. The sense 
exit pulse is available only until 340 s of a cycle dur¬ 
ing which a carriage skip operation is started. The 


sense printer instruction can be programmed before 
240 = but the pulse is not emitted until 240°. Ordi¬ 
narily a sense (printer) instruction follows immedi¬ 
ately after the write (printer) or read (printer) 
instruction. 

Extra-space, space-suppress. and non-print opera¬ 
tions may be controlled directly from sense exits. 
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